ossrv_pub/memory/inc/stdapis/stlport/stl/_new.h
author William Roberts <williamr@symbian.org>
Thu, 22 Jul 2010 16:48:56 +0100
branchGCC_SURGE
changeset 45 4b03adbd26ca
parent 22 ddc455616bd6
parent 31 ce057bb09d0b
permissions -rw-r--r--
Catchup to latest Symbian^4

/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/


#ifndef _STLP_NEW_H_HEADER
# define _STLP_NEW_H_HEADER

# ifdef _STLP_NO_BAD_ALLOC
# ifndef _STLP_NEW_DONT_THROW
#   define _STLP_NEW_DONT_THROW 1
# endif /* _STLP_NEW_DONT_THROW */

#  include <exception>


_STLP_BEGIN_NAMESPACE

#if defined(__SYMBIAN32__) && ( defined( __WINSCW__) || defined(__GCCXML__)) 

// already defined symcpp.h included from rvct2_2.h
struct nothrow_t {};
#endif



# ifdef _STLP_OWN_IOSTREAMS
#ifdef __ARMCC__
extern _STLP_DECLSPEC const nothrow_t nothrow;
#else
extern IMPORT_C const nothrow_t& GetNoThrowObj();
#define nothrow GetNoThrowObj()
#endif
# else
#  define nothrow nothrow_t()
# endif
#ifndef _STLP_EXCEPTION_BASE
#  define _STLP_EXCEPTION_BASE exception
#endif

class bad_alloc : public _STLP_EXCEPTION_BASE { 
public:
  bad_alloc () _STLP_NOTHROW_INHERENTLY { }
  bad_alloc(const bad_alloc&) _STLP_NOTHROW_INHERENTLY { }
  bad_alloc& operator=(const bad_alloc&) _STLP_NOTHROW_INHERENTLY {return *this;}
  ~bad_alloc () _STLP_NOTHROW_INHERENTLY { }
  const char* what() const _STLP_NOTHROW_INHERENTLY { return "bad alloc"; }
};

_STLP_END_NAMESPACE

#endif /* _STLP_NO_BAD_ALLOC */

#if defined (_STLP_WINCE)
_STLP_BEGIN_NAMESPACE

inline void* _STLP_CALL __stl_new(size_t __n) {
  return ::malloc(__n);
}

inline void _STLP_CALL __stl_delete(void* __p) {
  free(__p);
}

#ifndef __cdecl
# define __cdecl
#endif

_STLP_END_NAMESPACE

#else /* _STLP_WINCE */

#include <new>

# ifndef _STLP_NO_BAD_ALLOC
#  ifdef _STLP_USE_OWN_NAMESPACE

    _STLP_BEGIN_NAMESPACE
    using _STLP_VENDOR_EXCEPT_STD::bad_alloc;
    using _STLP_VENDOR_EXCEPT_STD::nothrow_t;
    using _STLP_VENDOR_EXCEPT_STD::nothrow;

#  if defined (_STLP_GLOBAL_NEW_HANDLER)
    using ::new_handler;
    using ::set_new_handler;
#  else
    using _STLP_VENDOR_EXCEPT_STD::new_handler;
    using _STLP_VENDOR_EXCEPT_STD::set_new_handler;
#  endif
    
    _STLP_END_NAMESPACE

#  endif /* _STLP_OWN_NAMESPACE */

# endif /* _STLP_NO_BAD_ALLOC */

# if defined (_STLP_NO_NEW_NEW_HEADER) || defined (_STLP_NEW_DONT_THROW) || defined (__SYMBIAN32__) \
                    || defined (__WINS__) && ! defined (_STLP_CHECK_NULL_ALLOC)
#  define _STLP_CHECK_NULL_ALLOC(__x) void* __y = __x;if (__y == 0){_STLP_THROW(bad_alloc());}return __y
# if defined (__SYMBIAN32__)
//# define _STLP_NEW operator new
#define _STLP_NEW  ::malloc
#endif
/*
# elif defined (__SYMBIAN32__) || defined (__WINS__)
#  ifndef _STLP_USE_TRAP_LEAVE
#   define _STLP_CHECK_NULL_ALLOC(__x) void* __y = __x;if (__y == 0){abort();}return __y
#  else
#   define _STLP_NEW(x) :: operator new (x, ELeave) 
#   define _STLP_CHECK_NULL_ALLOC(__x) return __x
#  endif
*/
# else
#  define _STLP_CHECK_NULL_ALLOC(__x) return __x
# endif

#ifndef _STLP_NEW
# define _STLP_NEW ::operator new
#endif
# define _STLP_PLACEMENT_NEW ::new

_STLP_BEGIN_NAMESPACE

#ifdef __SYMBIAN32__

typedef void(*new_handler)();

_STLP_DECLSPEC new_handler set_new_handler(new_handler pnew)  __NO_THROW;

#endif

#if (( defined(__IBMCPP__)|| defined(__OS400__) || defined (__xlC__) || defined (qTidyHeap)) && defined(__DEBUG_ALLOC__) )
inline void*  _STLP_CALL __stl_new(size_t __n) {  _STLP_CHECK_NULL_ALLOC(_STLP_NEW(__n, __FILE__, __LINE__)); }
inline void _STLP_CALL __stl_delete(void* __p) { ::operator delete(__p, __FILE__, __LINE__); }
#else
inline void*  _STLP_CALL __stl_new(size_t __n)   { return ::operator new(__n); }
inline void   _STLP_CALL __stl_delete(void* __p) { ::operator delete(__p); }
#endif
_STLP_END_NAMESPACE


# endif /* _STLP_WINCE */

#if defined(__SYMBIAN32__) && !defined(__GCCE__)
IMPORT_C void *operator new(unsigned int aSize);

IMPORT_C void *operator new[](unsigned int aSize);
#endif

IMPORT_C void operator delete(void* aPtr) __NO_THROW;

IMPORT_C void operator delete[](void* aPtr) __NO_THROW;

IMPORT_C void* operator new(unsigned int aSize, const std::nothrow_t& /*aNoThrow*/)  __NO_THROW;

IMPORT_C void* operator new[](unsigned int aSize, const std::nothrow_t& aNoThrow)  __NO_THROW;

IMPORT_C void operator delete(void* aPtr, const std::nothrow_t& /*aNoThrow*/)  __NO_THROW;

IMPORT_C void operator delete[](void* aPtr, const std::nothrow_t& /*aNoThrow*/)  __NO_THROW;


// placement delete
#ifndef __PLACEMENT_VEC_NEW_INLINE
#define __PLACEMENT_VEC_NEW_INLINE
inline void* operator new[](unsigned int /*aSize*/, void* aBase)  __NO_THROW
	{return aBase;}
inline void operator delete[](void* /*aPtr*/, void* /*aBase*/)  __NO_THROW
    {
    
    }
#endif

#ifndef __PLACEMENT_NEW_INLINE
#define __PLACEMENT_NEW_INLINE
inline void* operator new(unsigned int /*aSize*/, void* aBase)  __NO_THROW
	{return aBase;}

// Global placement operator delete
inline void operator delete(void* /*aPtr*/, void* /*aBase*/)  __NO_THROW
	{}
#endif //__PLACEMENT_NEW_INLINE


#endif /* _STLP_NEW_H_HEADER */