📄 plpython.h
字号:
/* $Header: /cvsroot/pgsql/src/pl/plpython/Attic/plpython.h,v 1.8 2003/07/25 23:37:30 tgl Exp $ */#ifndef PLPYTHON_H#define PLPYTHON_H#define DEBUG_EXC 0#define DEBUG_LEVEL 0#define DECLARE_N_EXC(N) int rv_##N; sigjmp_buf buf_##N#define TRAP_N_EXC(N) ((rv_##N = sigsetjmp(Warn_restart, 1)) != 0)#if !DEBUG_EXC#define RESTORE_N_EXC(N) memcpy(&Warn_restart, &(buf_##N), sizeof(sigjmp_buf))#define SAVE_N_EXC(N) memcpy(&(buf_##N), &Warn_restart, sizeof(sigjmp_buf))#define RERAISE_N_EXC(N) siglongjmp(Warn_restart, rv_##N)#define RAISE_EXC(V) siglongjmp(Warn_restart, (V))#else#define RESTORE_N_EXC(N) do { \ elog(WARNING, "exception (%d,%d) restore at %s:%d",\ PLy_call_level, exc_save_calls, __FUNCTION__, (__LINE__));\ exc_save_calls -= 1; \ memcpy(&Warn_restart, &(buf_##N), sizeof(sigjmp_buf)); } while (0)#define SAVE_N_EXC(N) do { \ exc_save_calls += 1; \ elog(WARNING, "exception (%d,%d) save at %s:%d", \ PLy_call_level, exc_save_calls, __FUNCTION__, (__LINE__)); \ memcpy(&(buf_##N), &Warn_restart, sizeof(sigjmp_buf)); } while (0)#define RERAISE_N_EXC(N) do { \ elog(WARNING, "exception (%d,%d) reraise at %s:%d", \ PLy_call_level, exc_save_calls, __FUNCTION__, (__LINE__)); \ siglongjmp(Warn_restart, rv_##N); } while (0)#define RAISE_EXC(V) do { \ elog(WARNING, "exception (%d,%d) raise at %s:%d", \ PLy_call_level, exc_save_calls, __FUNCTION__, (__LINE__)); \ siglongjmp(Warn_restart, (V)); } while (0)#endif#define DECLARE_EXC() DECLARE_N_EXC(save_restart)#define SAVE_EXC() SAVE_N_EXC(save_restart)#define RERAISE_EXC() RERAISE_N_EXC(save_restart)#define RESTORE_EXC() RESTORE_N_EXC(save_restart)#define TRAP_EXC() TRAP_N_EXC(save_restart)#if DEBUG_LEVEL#define CALL_LEVEL_INC() do { PLy_call_level += 1; \ elog(DEBUG4, "level: %d", PLy_call_level); } while (0)#define CALL_LEVEL_DEC() do { elog(DEBUG4, "level: %d", PLy_call_level); \ PLy_call_level -= 1; } while (0)#else#define CALL_LEVEL_INC() do { PLy_call_level += 1; } while (0)#define CALL_LEVEL_DEC() do { PLy_call_level -= 1; } while (0)#endif/* temporary debugging macros */#if DEBUG_LEVEL#define enter() elog(DEBUG4, "Enter(%d): %s", func_enter_calls++,__FUNCTION__)#define leave() elog(DEBUG4, "Leave(%d): %s", func_leave_calls++,__FUNCTION__)#define mark() elog(DEBUG4, "Mark: %s:%d", __FUNCTION__, __LINE__);#define refc(O) elog(DEBUG4, "Ref<%p>:<%d>:%s:%d", (O), (((O) == NULL) ? -1 : (O)->ob_refcnt), __FUNCTION__, __LINE__)#else#define enter()#define leave()#define mark()#define refc(O)#endif#endif /* PLPYTHON_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -