2003-08-19 15:19:38 -04:00
|
|
|
#include "scheme.h"
|
|
|
|
|
2003-08-25 11:59:18 -04:00
|
|
|
#include <new>
|
|
|
|
|
2003-08-19 15:19:38 -04:00
|
|
|
#ifdef USE_ATTC_PLUS_PLUS
|
|
|
|
# define set_new_handler set_new_handler__FPFv_v
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static Object New_Handler;
|
|
|
|
|
|
|
|
static void New_Handler_Proc () {
|
|
|
|
(void)Funcall (New_Handler, Null, 0);
|
|
|
|
}
|
|
|
|
|
2003-08-19 15:24:23 -04:00
|
|
|
static Object P_Set_New_Handler (Object p) {
|
2003-08-19 15:19:38 -04:00
|
|
|
Object old;
|
|
|
|
|
|
|
|
Check_Procedure (p);
|
|
|
|
old = New_Handler;
|
|
|
|
New_Handler = p;
|
|
|
|
return old;
|
|
|
|
}
|
|
|
|
|
2003-08-25 11:59:18 -04:00
|
|
|
extern "C" void elk_init_lib_cplusplus () {
|
2003-08-19 15:19:38 -04:00
|
|
|
New_Handler = Null;
|
|
|
|
Global_GC_Link (New_Handler);
|
2003-08-25 11:59:18 -04:00
|
|
|
std::new_handler (New_Handler_Proc);
|
2004-08-09 16:05:25 -04:00
|
|
|
Define_Primitive ((Object (*)())P_Set_New_Handler, "set-c++-new-handler!", 1, 1, EVAL);
|
2003-08-19 15:19:38 -04:00
|
|
|
}
|