williamr@2: /* williamr@2: * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. williamr@2: williamr@2: * Redistribution and use in source and binary forms, with or without williamr@2: * modification, are permitted provided that the following conditions are met: williamr@2: williamr@2: * Redistributions of source code must retain the above copyright notice, this williamr@2: * list of conditions and the following disclaimer. williamr@2: * Redistributions in binary form must reproduce the above copyright notice, williamr@2: * this list of conditions and the following disclaimer in the documentation williamr@2: * and/or other materials provided with the distribution. williamr@2: * Neither the name of Nokia Corporation nor the names of its contributors williamr@2: * may be used to endorse or promote products derived from this software williamr@2: * without specific prior written permission. williamr@2: williamr@2: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" williamr@2: * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE williamr@2: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE williamr@2: * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE williamr@2: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL williamr@2: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR williamr@2: * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER williamr@2: * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, williamr@2: * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE williamr@2: * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. williamr@2: * williamr@2: * Description: williamr@2: * williamr@2: */ williamr@2: williamr@2: #ifndef _STLP_NEW_H_HEADER williamr@2: # define _STLP_NEW_H_HEADER williamr@2: williamr@2: # ifdef _STLP_NO_BAD_ALLOC williamr@2: # ifndef _STLP_NEW_DONT_THROW williamr@2: # define _STLP_NEW_DONT_THROW 1 williamr@2: # endif /* _STLP_NEW_DONT_THROW */ williamr@2: williamr@2: # include williamr@2: williamr@2: williamr@2: _STLP_BEGIN_NAMESPACE williamr@2: williamr@2: #if defined(__SYMBIAN32__) && defined( __WINSCW__) williamr@2: // already defined symcpp.h included from rvct2_2.h williamr@2: struct nothrow_t {}; williamr@2: #endif williamr@2: williamr@2: williamr@2: # ifdef _STLP_OWN_IOSTREAMS williamr@2: #ifdef __ARMCC__ williamr@2: extern _STLP_DECLSPEC const nothrow_t nothrow; williamr@2: #else williamr@2: extern IMPORT_C const nothrow_t& GetNoThrowObj(); williamr@2: #define nothrow GetNoThrowObj() williamr@2: #endif williamr@2: # else williamr@2: # define nothrow nothrow_t() williamr@2: # endif williamr@2: #ifndef _STLP_EXCEPTION_BASE williamr@2: # define _STLP_EXCEPTION_BASE exception williamr@2: #endif williamr@2: williamr@2: class bad_alloc : public _STLP_EXCEPTION_BASE { williamr@2: public: williamr@2: bad_alloc () _STLP_NOTHROW_INHERENTLY { } williamr@2: bad_alloc(const bad_alloc&) _STLP_NOTHROW_INHERENTLY { } williamr@2: bad_alloc& operator=(const bad_alloc&) _STLP_NOTHROW_INHERENTLY {return *this;} williamr@2: ~bad_alloc () _STLP_NOTHROW_INHERENTLY { } williamr@2: const char* what() const _STLP_NOTHROW_INHERENTLY { return "bad alloc"; } williamr@2: }; williamr@2: williamr@2: _STLP_END_NAMESPACE williamr@2: williamr@2: #endif /* _STLP_NO_BAD_ALLOC */ williamr@2: williamr@2: #if defined (_STLP_WINCE) williamr@2: _STLP_BEGIN_NAMESPACE williamr@2: williamr@2: inline void* _STLP_CALL __stl_new(size_t __n) { williamr@2: return ::malloc(__n); williamr@2: } williamr@2: williamr@2: inline void _STLP_CALL __stl_delete(void* __p) { williamr@2: free(__p); williamr@2: } williamr@2: williamr@2: #ifndef __cdecl williamr@2: # define __cdecl williamr@2: #endif williamr@2: williamr@2: _STLP_END_NAMESPACE williamr@2: williamr@2: #else /* _STLP_WINCE */ williamr@2: williamr@2: #include williamr@2: williamr@2: # ifndef _STLP_NO_BAD_ALLOC williamr@2: # ifdef _STLP_USE_OWN_NAMESPACE williamr@2: williamr@2: _STLP_BEGIN_NAMESPACE williamr@2: using _STLP_VENDOR_EXCEPT_STD::bad_alloc; williamr@2: using _STLP_VENDOR_EXCEPT_STD::nothrow_t; williamr@2: using _STLP_VENDOR_EXCEPT_STD::nothrow; williamr@2: williamr@2: # if defined (_STLP_GLOBAL_NEW_HANDLER) williamr@2: using ::new_handler; williamr@2: using ::set_new_handler; williamr@2: # else williamr@2: using _STLP_VENDOR_EXCEPT_STD::new_handler; williamr@2: using _STLP_VENDOR_EXCEPT_STD::set_new_handler; williamr@2: # endif williamr@2: williamr@2: _STLP_END_NAMESPACE williamr@2: williamr@2: # endif /* _STLP_OWN_NAMESPACE */ williamr@2: williamr@2: # endif /* _STLP_NO_BAD_ALLOC */ williamr@2: williamr@2: # if defined (_STLP_NO_NEW_NEW_HEADER) || defined (_STLP_NEW_DONT_THROW) || defined (__SYMBIAN32__) \ williamr@2: || defined (__WINS__) && ! defined (_STLP_CHECK_NULL_ALLOC) williamr@2: # define _STLP_CHECK_NULL_ALLOC(__x) void* __y = __x;if (__y == 0){_STLP_THROW(bad_alloc());}return __y williamr@2: # if defined (__SYMBIAN32__) williamr@2: //# define _STLP_NEW operator new williamr@2: #define _STLP_NEW ::malloc williamr@2: #endif williamr@2: /* williamr@2: # elif defined (__SYMBIAN32__) || defined (__WINS__) williamr@2: # ifndef _STLP_USE_TRAP_LEAVE williamr@2: # define _STLP_CHECK_NULL_ALLOC(__x) void* __y = __x;if (__y == 0){abort();}return __y williamr@2: # else williamr@2: # define _STLP_NEW(x) :: operator new (x, ELeave) williamr@2: # define _STLP_CHECK_NULL_ALLOC(__x) return __x williamr@2: # endif williamr@2: */ williamr@2: # else williamr@2: # define _STLP_CHECK_NULL_ALLOC(__x) return __x williamr@2: # endif williamr@2: williamr@2: #ifndef _STLP_NEW williamr@2: # define _STLP_NEW ::operator new williamr@2: #endif williamr@2: # define _STLP_PLACEMENT_NEW ::new williamr@2: williamr@2: _STLP_BEGIN_NAMESPACE williamr@2: williamr@2: #ifdef __SYMBIAN32__ williamr@2: williamr@2: typedef void(*new_handler)(); williamr@2: williamr@2: _STLP_DECLSPEC new_handler set_new_handler(new_handler pnew) throw(); williamr@2: williamr@2: #endif williamr@2: williamr@2: #if (( defined(__IBMCPP__)|| defined(__OS400__) || defined (__xlC__) || defined (qTidyHeap)) && defined(__DEBUG_ALLOC__) ) williamr@2: inline void* _STLP_CALL __stl_new(size_t __n) { _STLP_CHECK_NULL_ALLOC(_STLP_NEW(__n, __FILE__, __LINE__)); } williamr@2: inline void _STLP_CALL __stl_delete(void* __p) { ::operator delete(__p, __FILE__, __LINE__); } williamr@2: #else williamr@2: inline void* _STLP_CALL __stl_new(size_t __n) { return ::operator new(__n); } williamr@2: inline void _STLP_CALL __stl_delete(void* __p) { ::operator delete(__p); } williamr@2: #endif williamr@2: _STLP_END_NAMESPACE williamr@2: williamr@2: williamr@2: # endif /* _STLP_WINCE */ williamr@2: williamr@2: #if defined(__SYMBIAN32__) && !defined(__GCCE__) williamr@2: _STLP_DECLSPEC void *operator new(unsigned int aSize); williamr@2: williamr@2: _STLP_DECLSPEC void *operator new[](unsigned int aSize); williamr@2: #endif williamr@2: williamr@2: _STLP_DECLSPEC void operator delete(void* aPtr) throw(); williamr@2: williamr@2: _STLP_DECLSPEC void operator delete[](void* aPtr) throw(); williamr@2: williamr@2: _STLP_DECLSPEC void* operator new(unsigned int aSize, const std::nothrow_t& /*aNoThrow*/) throw(); williamr@2: williamr@2: _STLP_DECLSPEC void* operator new[](unsigned int aSize, const std::nothrow_t& aNoThrow) throw(); williamr@2: williamr@2: _STLP_DECLSPEC void operator delete(void* aPtr, const std::nothrow_t& /*aNoThrow*/) throw(); williamr@2: williamr@2: _STLP_DECLSPEC void operator delete[](void* aPtr, const std::nothrow_t& /*aNoThrow*/) throw(); williamr@2: williamr@2: williamr@2: // placement delete williamr@2: #ifndef __PLACEMENT_VEC_NEW_INLINE williamr@2: #define __PLACEMENT_VEC_NEW_INLINE williamr@2: inline void* operator new[](unsigned int /*aSize*/, void* aBase) throw() williamr@2: {return aBase;} williamr@2: inline void operator delete[](void* /*aPtr*/, void* /*aBase*/) throw() williamr@2: { williamr@2: williamr@2: } williamr@2: #endif williamr@2: williamr@2: #ifndef __PLACEMENT_NEW_INLINE williamr@2: #define __PLACEMENT_NEW_INLINE williamr@2: inline void* operator new(unsigned int /*aSize*/, void* aBase) throw() williamr@2: {return aBase;} williamr@2: williamr@2: // Global placement operator delete williamr@2: inline void operator delete(void* /*aPtr*/, void* /*aBase*/) throw() williamr@2: {} williamr@2: #endif //__PLACEMENT_NEW_INLINE williamr@2: williamr@2: williamr@2: #endif /* _STLP_NEW_H_HEADER */