?? stl_config.h
字號:
/*
*
* Copyright (c) 1994
* Hewlett-Packard Company
*
* Copyright (c) 1996,1997
* Silicon Graphics Computer Systems, Inc.
*
* Copyright (c) 1997
* Moscow Center for SPARC Technology
*
* Copyright (c) 1999
* Boris Fomitchev
*
* This material is provided "as is", with absolutely no warranty expressed
* or implied. Any use is at your own risk.
*
* Permission to use or copy this software for any purpose is hereby granted
* without fee, provided the above notices are retained on all copies.
* Permission to modify the code and to distribute modified code is granted,
* provided the above notices are retained, and a notice that the code was
* modified is included with the above copyright notice.
*
*/
#ifndef __STL_CONFIG_H
# define __STL_CONFIG_H
/*
* Purpose of this file :
*
* Defines all STLport settings.
* This file is actually a wrapper : it includes compiler-specific
* settings from <config/stlcomp.h> (<config/stlconf.h>, if you ran "configure),
* and user-defined settings from <stl_user_config.h>.
* See <config/stl_mycomp.h> and <stl_user_config.h> for the description
* of those macros
*
*/
// Other macros defined by this file:
// * bool, true, and false, if __STL_NO_BOOL is defined.
// * typename, as a null macro if it's not already a keyword.
// * explicit, as a null macro if it's not already a keyword.
// * namespace-related macros (__STLPORT_STD, __STL_BEGIN_NAMESPACE, etc.)
// * exception-related macros (__STL_TRY, __STL_UNWIND, etc.)
// * __stl_assert, either as a test or as a null macro, depending on
// whether or not __STL_ASSERTIONS is defined.
// SGI basic release
# define __SGI_STL 0x320
// Adaptation version
# define __SGI_STL_PORT 0x320
// First, attempt to include config file produced by "configure"
# include <config/stlconf.h>
# if ! defined (__AUTO_CONFIGURED)
// Not configured, use per-version compiler recognition
# include <config/stlcomp.h>
# endif
//=========================================================
// some fixes to configuration, either "configure"d or
// hardcoded. This also includes modifications
// of STLport switches depending on compiler flags
# include <config/stl_confix.h>
//=========================================================
// Placeholder for user to override settings.
// It could be also used to mask settings from
// different directories
# include <stl_user_config.h>
//=========================================================
// SGI terms
#if !defined(__STL_HAS_NAMESPACES) && !defined(__STL_HAS_NO_NAMESPACES)
# define __STL_HAS_NAMESPACES 1
#endif
# if !defined (__STL_NO_PARTIAL_SPECIALIZATION_SYNTAX) && !defined (__STL_PARTIAL_SPECIALIZATION_SYNTAX)
# define __STL_PARTIAL_SPECIALIZATION_SYNTAX 1
# endif
# if !defined (__STL_NO_EXPLICIT_FUNCTION_TMPL_ARGS) && !defined(__STL_EXPLICIT_FUNCTION_TMPL_ARGS)
# define __STL_EXPLICIT_FUNCTION_TMPL_ARGS 1
# endif
# if !defined (__STL_NO_MEMBER_TEMPLATES) && !defined (__STL_MEMBER_TEMPLATES)
# define __STL_MEMBER_TEMPLATES 1
# endif
# if !defined (__STL_NO_FRIEND_TEMPLATES) && !defined (__STL_FRIEND_TEMPLATES)
# define __STL_FRIEND_TEMPLATES 1
# endif
# if !defined (__STL_NO_MEMBER_TEMPLATE_CLASSES) && !defined (__STL_MEMBER_TEMPLATE_CLASSES)
# define __STL_MEMBER_TEMPLATE_CLASSES 1
# endif
#if !defined (__STL_NO_CLASS_PARTIAL_SPECIALIZATION) && !defined (__STL_CLASS_PARTIAL_SPECIALIZATION)
# define __STL_CLASS_PARTIAL_SPECIALIZATION 1
#endif
#if !defined (__STL_FUNCTION_TMPL_PARTIAL_ORDER) && !defined (__STL_NO_FUNCTION_TMPL_PARTIAL_ORDER)
# define __STL_FUNCTION_TMPL_PARTIAL_ORDER 1
#endif
#if !defined(__STL_NO_TEMPLATE_CONVERSIONS) && !defined (__SGI_STL_USE_AUTO_PTR_CONVERSIONS)
# define __SGI_STL_USE_AUTO_PTR_CONVERSIONS
#endif
//==========================================================
// final workaround tuning based on given flags
//==========================================================
#ifndef __STL_UINT32_T
# define __STL_UINT32_T unsigned long
#endif
# if !defined (__STL_HAS_NO_NAMESPACES)
// undef only "USE"
# if defined __STL_NO_NAMESPACES
# undef __STL_USE_NAMESPACES
# else
// assume it as the default, turn it off later if NO_NAMESPACES selected
# undef __STL_USE_NAMESPACES
# define __STL_USE_NAMESPACES 1
# endif
# endif
# ifndef __STLPORT_NAMESPACE
# define __STLPORT_NAMESPACE stlport
# endif
# if !defined (__STL_HAS_NO_NEW_IOSTREAMS) && !defined (__STL_USE_NEW_IOSTREAMS)
# define __STL_USE_NEW_IOSTREAMS
# endif
# if defined (__STL_NO_NEW_IOSTREAMS)
# undef __STL_USE_NEW_IOSTREAMS
# endif
# if defined (__STL_USE_NEW_IOSTREAMS) && \
defined (__STL_USE_NAMESPACES) && !defined (__STL_BROKEN_USING_DIRECTIVE) && \
!defined(__STL_STD_REBUILD) && !defined(__STL_NO_OWN_NAMESPACE)
# undef __STL_USE_OWN_NAMESPACE
# define __STL_USE_OWN_NAMESPACE 1
# else
// if this is somehow set, undefine it, as it is not meaningful
# undef __STL_WHOLE_NATIVE_STD
# endif
# if defined(_PTHREADS) && !defined(_NOTHREADS)
# define __STL_PTHREADS
# endif
# if defined(_UITHREADS) && !defined(_NOTHREADS)
# define __STL_UITHREADS
# endif
# ifdef _REENTRANT
# if !defined(_NOTHREADS) && !defined(_PTHREADS)
# if defined (__sgi)
# define __STL_SGI_THREADS
# elif (defined (__sun) && defined (__SVR4)) || \
(defined(_UITHREADS) || defined (__STL_SOLARIS_THREADS) && !defined(_NOTHREADS))
# define __STL_UITHREADS
# elif defined (_WIN32) || defined (WIN32) || defined (__WIN32__)
# define __STL_WIN32THREADS
# else
# define __STL_PTHREADS
# endif /* __sgi */
# endif /* _NOTHREADS */
# endif /* _REENTRANT */
# if defined (_MFC_VER) && !defined (__STL_USE_MFC)
# define __STL_USE_MFC 1
# endif
#if defined(__STL_WIN32THREADS) || defined(STL_SGI_THREADS) \
|| defined(__STL_PTHREADS) || defined(__STL_UITHREADS)
# define __STL_THREADS
# define __STL_VOLATILE volatile
// windows.h _MUST be included before bool definition ;(
# if defined (__STL_WIN32THREADS) && defined (__STL_NO_BOOL)
# define NOMINMAX
# ifdef __STL_USE_MFC
# include <afx.h>
# else
# include <windows.h>
# endif
# undef min
# undef max
# define __STLPORT_WINDOWS_H_INCLUDED
# endif
#else
# define __STL_VOLATILE
#endif
# if !defined ( __STL_USE_NEW_C_HEADERS ) && !defined ( __STL_HAS_NO_NEW_C_HEADERS )
# define __STL_USE_NEW_C_HEADERS
# endif
// disable new-style headers if requested
# if defined ( __STL_NO_NEW_C_HEADERS )
# undef __STL_USE_NEW_C_HEADERS
# endif
# if defined ( __STL_NO_STATIC_TEMPLATE_DATA )
# define __STL_STATIC_TEMPLATE_DATA 0
# if !defined ( __STL_WEAK_ATTRIBUTE )
# define __STL_WEAK_ATTRIBUTE 0
# endif
# else
# define __STL_STATIC_TEMPLATE_DATA 1
# endif
#ifdef __STL_STATIC_CONST_INIT_BUG
# define __STL_INLINE_STATIC_INIT(x)
# define __STL_OUTLINE_STATIC_INIT(x) = x
#else
# define __STL_INLINE_STATIC_INIT(x) = x
# define __STL_OUTLINE_STATIC_INIT(x)
#endif
# if defined (__STL_BASE_TYPEDEF_BUG)
# undef __STL_BASE_TYPEDEF_OUTSIDE_BUG
# define __STL_BASE_TYPEDEF_OUTSIDE_BUG 1
# endif
# if defined ( __STL_NESTED_TYPE_PARAM_BUG ) || (defined (__STL_MSVC) && (__STL_MSVC < 1100))
# define __STL_GLOBAL_NESTED_RETURN_TYPE_PARAM_BUG
# endif
// SUNpro 4.2 inline string literal bug
#ifdef __STL_INLINE_STRING_LITERAL_BUG
# define __STL_FIX_LITERAL_BUG(__x) __x=__x;
#else
# define __STL_FIX_LITERAL_BUG(__x)
#endif
// comment this section if you want to use BufSize parameter
// of deque (note that no template function taking deque<T,Alloc,BufSize>
// as parameter will compile then)
# if defined (__STL_NON_TYPE_TMPL_PARAM_BUG)
# undef __STL_NO_DEFAULT_NON_TYPE_PARAM
# define __STL_NO_DEFAULT_NON_TYPE_PARAM 1
# endif
# define __STL_NEW new
# define __STL_PLACEMENT_NEW new
// features tuning
# ifdef __STL_DEBUG
# define __STL_ASSERTIONS 1
# endif
// if __STL_DEBUG or __STL_ASSERTIONS are set, stldebug.h defines those
# ifndef __STL_ASSERTIONS
# define __stl_assert(expr) do {} while(0) // dwa 3/19/99 - prevents 'unwanted ;' warning
# endif
# ifndef __STL_DEBUG
# define __stl_verbose_assert(expr,diagnostic)
# define __stl_debug_check(expr)
# define __stl_debug_do(expr)
# endif
// tuning of static template data members workaround
# if ( __STL_STATIC_TEMPLATE_DATA < 1 )
// ignore __PUT directive in this case
# if ( __STL_WEAK_ATTRIBUTE > 0 )
# define __STL_WEAK __attribute__ (( weak ))
# define __DECLARE_INSTANCE(type,item,init) type item __attribute__ (( weak )) init
# else
# define __STL_WEAK
# ifdef __PUT_STATIC_DATA_MEMBERS_HERE
# define __DECLARE_INSTANCE(type,item,init) type item init
# else
# define __DECLARE_INSTANCE(type,item,init)
# endif /* __PUT_STATIC_DATA_MEMBERS_HERE */
# endif /* __STL_WEAK_ATTRIBUTE */
# endif /* __STL_STATIC_TEMPLATE_DATA */
// default parameters as template types derived from arguments ( not always supported )
# if defined (__STL_LIMITED_DEFAULT_TEMPLATES)
# define __DFL_TMPL_PARAM( classname, defval ) class classname
# define __DFL_TMPL_ARG(classname) , classname
# else
# define __STL_DEFAULT_TYPE_PARAM 1
# define __DFL_TMPL_PARAM( classname, defval ) class classname = defval
# define __DFL_TMPL_ARG(classname)
# endif
// default parameters as complete types
# if defined ( __STL_DEFAULT_TYPE_PARAM )
# define __DFL_TYPE_PARAM( classname, defval ) class classname = defval
# define __DFL_NON_TYPE_PARAM(type,name,val) type name = val
# define __DFL_TYPE_ARG(classname)
# else
# define __DFL_TYPE_PARAM( classname, defval ) class classname
# define __DFL_NON_TYPE_PARAM(type,name,val) type name
# define __DFL_TYPE_ARG(classname) , classname
# endif
// SGI compatibility
#ifndef __STL_NO_WCHAR_T
# define __STL_HAS_WCHAR_T
#endif
#if !defined (__STL_NO_AT_MEMBER_FUNCTION)
# define __STL_CAN_THROW_RANGE_ERRORS 1
#endif
// __STL_USE_SGI_ALLOCATORS is a hook so that users can
// disable allocator<_Tp> as default, and continue to use the same kind of
// allocators as before, without having to edit library headers.
# if !defined (__STL_USE_SGI_ALLOCATORS)
# define __STL_DEFAULT_ALLOCATOR(_Tp) allocator< _Tp >
# define __STL_DEFAULT_ALLOCATOR_SELECT( _Tp ) __DFL_TMPL_PARAM(_Alloc,allocator< _Tp >)
# define __STL_DEFAULT_PAIR_ALLOCATOR(_Key, _Tp) allocator< pair < _Key, _Tp > >
# if defined (__STL_LIMITED_DEFAULT_TEMPLATES)
# define __STL_DEFAULT_PAIR_ALLOCATOR_SELECT(_Key, _Tp ) class _Alloc
# define __STL_USE_WRAPPER_FOR_ALLOC_PARAM 1
# else
# define __STL_DEFAULT_PAIR_ALLOCATOR_SELECT(_Key, _Tp ) class _Alloc = allocator< pair < _Key, _Tp > >
# endif
# else
# define __STL_DEFAULT_ALLOCATOR( _Tp ) __sgi_alloc
# define __STL_DEFAULT_ALLOCATOR_SELECT( _Tp ) __DFL_TYPE_PARAM(_Alloc,__sgi_alloc)
# define __STL_DEFAULT_PAIR_ALLOCATOR( _Key, _Tp ) __sgi_alloc
# define __STL_DEFAULT_PAIR_ALLOCATOR_SELECT(_Key, _Tp ) __DFL_TYPE_PARAM(_Alloc,__sgi_alloc)
# if defined (__STL_LIMITED_DEFAULT_TEMPLATES) && !defined (__STL_DEFAULT_TYPE_PARAM)
# define __STL_USE_WRAPPER_FOR_ALLOC_PARAM 1
# endif
# endif
// default parameters workaround tuning
# if defined ( __STL_USE_WRAPPER_FOR_ALLOC_PARAM )
# define __WORKAROUND_RENAME(X) __##X
# else
# define __WORKAROUND_RENAME(X) X
# endif
# define __FULL_NAME(X) __WORKAROUND_RENAME(X)
// macro to convert the allocator for initialization
// not using MEMBER_TEMPLATE_CLASSES as it should work given template constructor
#if defined (__STL_MEMBER_TEMPLATES) || ! defined (__STL_CLASS_PARTIAL_SPECIALIZATION)
// if __STL_NO_TEMPLATE_CONVERSIONS is set, the member template constructor is
// not used implicitly to convert allocator parameter, so let us do it explicitly
# if defined (__STL_MEMBER_TEMPLATE_CLASSES) && defined (__STL_NO_TEMPLATE_CONVERSIONS)
# define __STL_CONVERT_ALLOCATOR(__a, _Tp) __a.rebind<_Tp>::other(__a)
# else
# define __STL_CONVERT_ALLOCATOR(__a, _Tp) __a
# endif
// else convert, but only if partial specialization works, since else
// Container::allocator_type won't be different
#else
# define __STL_CONVERT_ALLOCATOR(__a, _Tp) __stl_alloc_create(__a,(_Tp*)0)
#endif
#ifdef __STL_MEMBER_TEMPLATE_CLASSES
# define __STL_REBIND_ALLOCATOR(__a, _Tp) __a
#else
# define __STL_REBIND_ALLOCATOR(__a, _Tp) __stl_alloc_rebind(__a,(_Tp*)0)
#endif
// parameters passed to container's constructors.
// some compilers choke on default parameters
// given as a constructor name
# if defined (__STL_DEFAULT_PARAM_CONSTRUCTOR_BUG)
# define __STL_ALLOC_INSTANCE(_X) _STL_factory<_X>::_Instance()
# else
# define __STL_ALLOC_INSTANCE(_X) _X()
# endif
// namespace stuff adjustment
// Depending of whether compiler supports namespaces,
// tune the parameters for vendor-supplied libraries
# if !defined (__STL_HAS_NO_NAMESPACES)
// if using stlport:: namespace or if C library stuff is not in vendor's std::,
// try importing 'em.
// MSVC has ambiguity problem when we try to import C-style std:: stuff into global namespace
# if ( defined(__STL_USE_OWN_NAMESPACE) || defined (__STL_VENDOR_GLOBAL_CSTD)) && \
! ( defined (__STL_MSVC) && __STL_MSVC <= 1200 && ! defined (__ICL) )
# define __STL_IMPORT_VENDOR_CSTD 1
# endif
# define __STL_USING_NAMESPACE(x) using namespace x ;
// assume std:: namespace for C++ std library if not being told otherwise
# ifdef __STL_VENDOR_GLOBAL_STD
# define __STL_VENDOR_STD
# define __STL_USING_VENDOR_STD
# else
# define __STL_VENDOR_STD std
# define __STL_USING_VENDOR_STD __STL_USING_NAMESPACE(__STL_VENDOR_STD)
# endif
// tune things that come from C library
# if defined (__STL_VENDOR_GLOBAL_CSTD) || !defined(__STL_USE_NEW_C_HEADERS)
// in old-style headers, C functions go to global scope.
# define __STL_VENDOR_CSTD
# define __STL_USING_VENDOR_CSTD
# else
# define __STL_VENDOR_CSTD __STL_VENDOR_STD
# define __STL_USING_VENDOR_CSTD __STL_USING_NAMESPACE(__STL_VENDOR_CSTD)
# endif /* __STL_VENDOR_CSTD */
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -