/* * * 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. * */ #define _STLP_EXPOSE_GLOBALS_IMPLEMENTATION #include "stlport_prefix.h" #if !defined (_STLP_DEBUG) && ! defined (_STLP_ASSERTIONS) # if !defined (__APPLE__) || !defined (__GNUC__) || (__GNUC__ < 3) || ((__GNUC__ == 3) && (__GNUC_MINOR__ < 3)) /* dums: Please if the following code was being uncommented please explain why * as for the moment it only looks like a source of inconsistency in the way * STLport different translation units are compiled. */ //# define _STLP_ASSERTIONS 1 # endif #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #if defined (__DMC__) // for rope static members # include #endif #include _STLP_BEGIN_NAMESPACE #if defined (_STLP_NO_EXCEPTION_HEADER) || defined (_STLP_BROKEN_EXCEPTION_CLASS) exception::exception() _STLP_NOTHROW {} exception::~exception() _STLP_NOTHROW {} bad_exception::bad_exception() _STLP_NOTHROW {} bad_exception::~bad_exception() _STLP_NOTHROW {} const char* exception::what() const _STLP_NOTHROW { return "class exception"; } const char* bad_exception::what() const _STLP_NOTHROW { return "class bad_exception"; } #endif #if defined (_STLP_OWN_STDEXCEPT) # include // boris : those are needed to force typeinfo nodes to be created in here only logic_error::~logic_error() _STLP_NOTHROW_INHERENTLY {} runtime_error::~runtime_error() _STLP_NOTHROW_INHERENTLY {} domain_error::~domain_error() _STLP_NOTHROW_INHERENTLY {} invalid_argument::~invalid_argument() _STLP_NOTHROW_INHERENTLY {} length_error::~length_error() _STLP_NOTHROW_INHERENTLY {} out_of_range::~out_of_range() _STLP_NOTHROW_INHERENTLY {} range_error::~range_error() _STLP_NOTHROW_INHERENTLY {} overflow_error::~overflow_error() _STLP_NOTHROW_INHERENTLY {} underflow_error::~underflow_error() _STLP_NOTHROW_INHERENTLY {} #endif #if !defined(_STLP_WCE_EVC3) # if defined (_STLP_NO_BAD_ALLOC) const nothrow_t nothrow /* = {} */; # endif #endif #if !defined (_STLP_NO_FORCE_INSTANTIATE) # if defined (_STLP_DEBUG) || defined (_STLP_ASSERTIONS) _STLP_MOVE_TO_PRIV_NAMESPACE template class _STLP_CLASS_DECLSPEC __stl_debug_engine; _STLP_MOVE_TO_STD_NAMESPACE # endif template class _STLP_CLASS_DECLSPEC __debug_alloc<__node_alloc>; template class _STLP_CLASS_DECLSPEC __debug_alloc<__new_alloc>; //Export of the types used to represent buckets in the hashtable implementation. /* * For the vector class we do not use any MSVC6 workaround even if we export it from * the STLport dynamic libraries because we know what methods are called and none is * a template method. Moreover the exported class is an instanciation of vector with * _Slist_node_base struct that is an internal STLport class that no user should ever * use. */ # if !defined (_STLP_USE_PTR_SPECIALIZATIONS) template class _STLP_CLASS_DECLSPEC allocator<_STLP_PRIV _Slist_node_base*>; _STLP_MOVE_TO_PRIV_NAMESPACE template class _STLP_CLASS_DECLSPEC _STLP_alloc_proxy<_Slist_node_base**, _Slist_node_base*, allocator<_Slist_node_base*> >; template class _STLP_CLASS_DECLSPEC _Vector_base<_Slist_node_base*, allocator<_Slist_node_base*> >; _STLP_MOVE_TO_STD_NAMESPACE # endif # if defined (_STLP_DEBUG) _STLP_MOVE_TO_PRIV_NAMESPACE template class _STLP_CLASS_DECLSPEC _STLP_NON_DBG_NAME(vector)<_Slist_node_base*, allocator<_Slist_node_base*> >; _STLP_MOVE_TO_STD_NAMESPACE # endif template class _STLP_CLASS_DECLSPEC vector<_STLP_PRIV _Slist_node_base*, allocator<_STLP_PRIV _Slist_node_base*> >; //End of hashtable bucket types export. //Export of _Locale_impl facets container: # if !defined (_STLP_USE_PTR_SPECIALIZATIONS) template class _STLP_CLASS_DECLSPEC allocator; _STLP_MOVE_TO_PRIV_NAMESPACE template class _STLP_CLASS_DECLSPEC _STLP_alloc_proxy >; template class _STLP_CLASS_DECLSPEC _Vector_base >; _STLP_MOVE_TO_STD_NAMESPACE # endif # if defined (_STLP_DEBUG) _STLP_MOVE_TO_PRIV_NAMESPACE # define _STLP_NON_DBG_VECTOR _STLP_NON_DBG_NAME(vector) template class _STLP_CLASS_DECLSPEC __construct_checker<_STLP_PRIV _STLP_NON_DBG_VECTOR > >; template class _STLP_CLASS_DECLSPEC _STLP_NON_DBG_VECTOR >; # undef _STLP_NON_DBG_VECTOR _STLP_MOVE_TO_STD_NAMESPACE # endif template class _STLP_CLASS_DECLSPEC vector >; //End of export of _Locale_impl facets container. # if defined (_STLP_USE_PTR_SPECIALIZATIONS) template class _STLP_CLASS_DECLSPEC allocator; typedef _STLP_PRIV _List_node _VoidPtr_Node; template class _STLP_CLASS_DECLSPEC allocator<_VoidPtr_Node>; _STLP_MOVE_TO_PRIV_NAMESPACE template class _STLP_CLASS_DECLSPEC _STLP_alloc_proxy >; template class _STLP_CLASS_DECLSPEC _Vector_base >; template class _STLP_CLASS_DECLSPEC _STLP_PTR_IMPL_NAME(vector) >; template class _STLP_CLASS_DECLSPEC _List_node; template class _STLP_CLASS_DECLSPEC _STLP_alloc_proxy<_List_node_base, _VoidPtr_Node, allocator<_VoidPtr_Node> >; template class _STLP_CLASS_DECLSPEC _List_base >; template class _STLP_CLASS_DECLSPEC _STLP_PTR_IMPL_NAME(list) >; template class _STLP_CLASS_DECLSPEC _Slist_node; template class _STLP_CLASS_DECLSPEC _STLP_alloc_proxy<_Slist_node_base, _Slist_node, allocator<_Slist_node > >; template class _STLP_CLASS_DECLSPEC _Slist_base >; template class _STLP_CLASS_DECLSPEC _STLP_PTR_IMPL_NAME(slist) >; template class _STLP_CLASS_DECLSPEC _STLP_alloc_proxy >; template class _STLP_CLASS_DECLSPEC _STLP_alloc_proxy >; template struct _STLP_CLASS_DECLSPEC _Deque_iterator >; template class _STLP_CLASS_DECLSPEC _Deque_base >; template class _STLP_CLASS_DECLSPEC _STLP_PTR_IMPL_NAME(deque) >; _STLP_MOVE_TO_STD_NAMESPACE # endif /* _STLP_USE_PTR_SPECIALIZATIONS */ _STLP_MOVE_TO_PRIV_NAMESPACE template class _STLP_CLASS_DECLSPEC _Rb_global; template class _STLP_CLASS_DECLSPEC _List_global; template class _STLP_CLASS_DECLSPEC _Sl_global; template class _STLP_CLASS_DECLSPEC _Stl_prime; template class _STLP_CLASS_DECLSPEC _LimG; _STLP_MOVE_TO_STD_NAMESPACE #endif /* _STLP_NO_FORCE_INSTANTIATE */ _STLP_END_NAMESPACE #if defined (_STLP_SIGNAL_RUNTIME_COMPATIBILITY) extern "C" void _STLP_DECLSPEC _STLP_CALL _STLP_SIGNAL_RUNTIME_COMPATIBILITY() {} #endif #define FORCE_SYMBOL extern #if defined (_WIN32) && defined (_STLP_USE_DECLSPEC) && !defined (_STLP_USE_STATIC_LIB) // stlportmt.cpp : Defines the entry point for the DLL application. // # undef FORCE_SYMBOL # define FORCE_SYMBOL APIENTRY extern "C" { BOOL APIENTRY DllMain( HANDLE hModule, DWORD ul_reason_for_call, LPVOID) { switch (ul_reason_for_call) { case DLL_PROCESS_ATTACH: DisableThreadLibraryCalls((HINSTANCE)hModule); case DLL_THREAD_ATTACH: case DLL_THREAD_DETACH: case DLL_PROCESS_DETACH: break; } return TRUE; } } /* extern "C" */ #if !defined (_STLP_MSVC) && !defined (__MINGW32__) _STLP_BEGIN_NAMESPACE static void FORCE_SYMBOL force_link() { set::iterator iter; // _M_increment; _M_decrement instantiation ++iter; --iter; } _STLP_END_NAMESPACE #endif #endif /* _WIN32 */ #if defined (__ICL) && (__ICL >= 900) && (_STLP_MSVC_LIB < 1300) # undef std namespace std { void _STLP_CALL unexpected() { unexpected_handler hdl; set_unexpected(hdl = set_unexpected((unexpected_handler)0)); hdl(); } } #endif