Commit 55e77764 by Mike Stump

90th Cygnus<->FSF quick merge

From-SVN: r13605
parent 824b9a4c
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
#pragma interface "new" #pragma interface "new"
#include <stddef.h> #include <stddef.h>
#include <exception>
extern "C++" { extern "C++" {
...@@ -13,8 +14,15 @@ extern "C++" { ...@@ -13,8 +14,15 @@ extern "C++" {
namespace std { namespace std {
#endif #endif
typedef void (*new_handler)(); class bad_alloc : public exception {
extern "C" new_handler set_new_handler (new_handler); public:
virtual const char* what() const throw() { return "bad_alloc"; }
};
struct nothrow_t {};
extern const nothrow_t nothrow;
typedef void (*new_handler)();
extern "C" new_handler set_new_handler (new_handler);
#if 0 #if 0
} // namespace std } // namespace std
...@@ -26,13 +34,15 @@ extern "C" void __default_new_handler (void); ...@@ -26,13 +34,15 @@ extern "C" void __default_new_handler (void);
// replaceable signatures // replaceable signatures
void *operator new (size_t); void *operator new (size_t);
void *operator new (size_t, const nothrow_t&) throw();
void *operator new[] (size_t); void *operator new[] (size_t);
void operator delete (void *); void *operator new[] (size_t, const nothrow_t&) throw();
void operator delete[] (void *); void operator delete (void *) throw();
void operator delete[] (void *) throw();
// default placement versions of operator new // default placement versions of operator new
inline void *operator new(size_t, void *place) { return place; } inline void *operator new(size_t, void *place) throw() { return place; }
inline void *operator new[](size_t, void *place) { return place; } inline void *operator new[](size_t, void *place) throw() { return place; }
} // extern "C++" } // extern "C++"
#endif #endif
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment