📄 cmdebprn.c
字号:
/***********************************************************************
Copyright (c) 2002 RADVISION Ltd.
************************************************************************
NOTICE:
This document contains information that is confidential and proprietary
to RADVISION Ltd.. No part of this document may be reproduced in any
form whatsoever without written prior approval by RADVISION Ltd..
RADVISION Ltd. reserve the right to revise this publication and make
changes without obligation to notify any person of such revisions or
changes.
***********************************************************************/
#include "rvinternal.h"
#include "rvstdio.h"
#include "cmintr.h"
#include "cmdebprn.h"
#ifdef __cplusplus
extern "C" {
#endif
/* Make sure that both ENTER and LEAVE are declared */
#if (RV_LOGMASK_COMPILEMASK & (RV_LOGLEVEL_ENTER || RV_LOGLEVEL_LEAVE))
#if (!(RV_LOGMASK_COMPILEMASK & RV_LOGLEVEL_ENTER))
#error RV_LOGMASK_COMPILEMASK must have both ENTER and LEAVE. It cannot have only LEAVE!
#endif
#if (!(RV_LOGMASK_COMPILEMASK & RV_LOGLEVEL_LEAVE))
#error RV_LOGMASK_COMPILEMASK must have both ENTER and LEAVE. It cannot have only ENTER!
#endif
#endif
#if defined(cmiAPIEnter)
#undef cmiAPIEnter
#endif
#if defined(cmiAPIExit)
#undef cmiAPIExit
#endif
#if defined(cmiCBEnter)
#undef cmiCBEnter
#endif
#if defined(cmiCBExit)
#undef cmiCBExit
#endif
void cmiAPIEnter(HAPP hApp,const char*line,...)
{
#if (RV_LOGMASK_COMPILEMASK & RV_LOGLEVEL_ENTER)
cmElem* app = (cmElem *)hApp;
if (RvLogIsSelected(&app->logAPI, RV_LOGLEVEL_ENTER))
{
char buf[1024];
va_list v;
va_start(v, line);
RvVsprintf(buf, line, v);
cmLock(hApp);
app->level++;
RvLogTextEnter(&app->logAPI, "%d >>>%*c%s", app->level, app->level * 3, ' ', buf);
cmUnlock(hApp);
}
#else
RV_UNUSED_ARG(hApp);
RV_UNUSED_ARG(line);
#endif
}
void cmiAPIExit(HAPP hApp,const char*line,...)
{
#if (RV_LOGMASK_COMPILEMASK & RV_LOGLEVEL_LEAVE)
cmElem* app = (cmElem *)hApp;
if (RvLogIsSelected(&app->logAPI, RV_LOGLEVEL_LEAVE))
{
char buf[1024];
va_list v;
va_start(v, line);
RvVsprintf(buf, line, v);
cmLock(hApp);
RvLogTextLeave(&app->logAPI, "%d <<<%*c%s", app->level, app->level * 3, ' ', buf);
app->level--;
cmUnlock(hApp);
}
#else
RV_UNUSED_ARG(hApp);
RV_UNUSED_ARG(line);
#endif
}
void cmiCBEnter(HAPP hApp,const char*line,...)
{
#if (RV_LOGMASK_COMPILEMASK & RV_LOGLEVEL_ENTER)
cmElem* app = (cmElem *)hApp;
if (RvLogIsSelected(&app->logCB, RV_LOGLEVEL_ENTER))
{
char buf[1024];
va_list v;
va_start(v, line);
RvVsprintf(buf, line, v);
cmLock(hApp);
app->level++;
RvLogTextEnter(&app->logCB, "%d >>>%*c%s", app->level, app->level * 3, ' ', buf);
cmUnlock(hApp);
}
#else
RV_UNUSED_ARG(hApp);
RV_UNUSED_ARG(line);
#endif
}
void cmiCBExit(HAPP hApp,const char*line,...)
{
#if (RV_LOGMASK_COMPILEMASK & RV_LOGLEVEL_LEAVE)
cmElem* app = (cmElem *)hApp;
if (RvLogIsSelected(&app->logCB, RV_LOGLEVEL_LEAVE))
{
char buf[1024];
va_list v;
va_start(v, line);
RvVsprintf(buf, line, v);
cmLock(hApp);
RvLogTextLeave(&app->logCB, "%d <<<%*c%s", app->level, app->level * 3, ' ', buf);
app->level--;
cmUnlock(hApp);
}
#else
RV_UNUSED_ARG(hApp);
RV_UNUSED_ARG(line);
#endif
}
#ifdef __cplusplus
}
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -