You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
sems/core/ampi/MonitoringAPI.h

229 lines
8.6 KiB

#ifndef _MONITORING_API_H
#define _MONITORING_API_H
/*
* macros to make monitoring easy to use and not
* mess up source code too much
*/
#ifdef USE_MONITORING
#define MONITORING_LOG(callid, property, value) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args,ret; \
di_args.push(AmArg(callid)); \
di_args.push(AmArg(property)); \
di_args.push(AmArg(value)); \
AmSessionContainer::monitoring_di->invoke("log", di_args, ret); \
} \
// hm... there must be a better method for this...
#define MONITORING_LOG2(callid, prop1, val1, prop2, val2) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args,ret; \
di_args.push(AmArg(callid)); \
di_args.push(AmArg(prop1)); \
di_args.push(AmArg(val1)); \
di_args.push(AmArg(prop2)); \
di_args.push(AmArg(val2)); \
AmSessionContainer::monitoring_di->invoke("log", di_args, ret); \
} \
#define MONITORING_LOG3(callid, prop1, val1, prop2, val2, prop3, val3) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args,ret; \
di_args.push(AmArg(callid)); \
di_args.push(AmArg(prop1)); \
di_args.push(AmArg(val1)); \
di_args.push(AmArg(prop2)); \
di_args.push(AmArg(val2)); \
di_args.push(AmArg(prop3)); \
di_args.push(AmArg(val3)); \
AmSessionContainer::monitoring_di->invoke("log", di_args, ret); \
} \
#define MONITORING_LOG4(callid, prop1, val1, prop2, val2, prop3, val3, prop4, val4) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args,ret; \
di_args.push(AmArg(callid)); \
di_args.push(AmArg(prop1)); \
di_args.push(AmArg(val1)); \
di_args.push(AmArg(prop2)); \
di_args.push(AmArg(val2)); \
di_args.push(AmArg(prop3)); \
di_args.push(AmArg(val3)); \
di_args.push(AmArg(prop4)); \
di_args.push(AmArg(val4)); \
AmSessionContainer::monitoring_di->invoke("log", di_args, ret); \
} \
#define MONITORING_LOG5(callid, prop1, val1, prop2, val2, prop3, val3, prop4, val4, prop5, val5) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args,ret; \
di_args.push(AmArg(callid)); \
di_args.push(AmArg(prop1)); \
di_args.push(AmArg(val1)); \
di_args.push(AmArg(prop2)); \
di_args.push(AmArg(val2)); \
di_args.push(AmArg(prop3)); \
di_args.push(AmArg(val3)); \
di_args.push(AmArg(prop4)); \
di_args.push(AmArg(val4)); \
di_args.push(AmArg(prop5)); \
di_args.push(AmArg(val5)); \
AmSessionContainer::monitoring_di->invoke("log", di_args, ret); \
} \
#define MONITORING_LOG_ADD(callid, property, value) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args,ret; \
di_args.push(AmArg(callid)); \
di_args.push(AmArg(property)); \
di_args.push(AmArg(value)); \
AmSessionContainer::monitoring_di->invoke("logAdd", di_args, ret); \
} \
#define MONITORING_INC(type, name) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args, ret; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(name)); \
AmSessionContainer::monitoring_di->invoke("inc", di_args, ret); \
} \
#define MONITORING_DEC(type, name) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args, ret; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(name)); \
AmSessionContainer::monitoring_di->invoke("dec", di_args, ret); \
} \
#define MONITORING_ADD(type, name, val) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args, ret; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(name)); \
di_args.push(AmArg(val)); \
AmSessionContainer::monitoring_di->invoke("addCount", di_args, ret); \
} \
#define MONITORING_GET(type, ret) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args; \
di_args.push(AmArg(type)); \
AmSessionContainer::monitoring_di->invoke("get", di_args, ret); \
} \
#define MONITORING_GET_SINGLE(type, name, ret) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(name)); \
AmSessionContainer::monitoring_di->invoke("getSingle", di_args, ret); \
} \
#define MONITORING_ADD_SAMPLE_VALUE(type, name, value) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args, ret; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(name)); \
di_args.push(AmArg(value)); \
MONITORING_GLOBAL_INTERFACE->invoke("addSample", di_args, ret); \
} \
#define MONITORING_ADD_SAMPLE_VALUE_NOW(type, name, value, _now) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args, ret; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(name)); \
di_args.push(AmArg(value)); \
di_args.push(AmArg(ArgBlob((const char*)&_now, sizeof(_now)))); \
MONITORING_GLOBAL_INTERFACE->invoke("addSample", di_args, ret); \
} \
#define MONITORING_ADD_SAMPLE_NOW(type, name, _now) \
MONITORING_ADD_SAMPLE_VALUE_NOW(type, name, 1, _now)
#define MONITORING_ADD_SAMPLE(type, name) \
MONITORING_ADD_SAMPLE_VALUE(type, name, 1)
#define MONITORING_GET_COUNT_SEC(type, name, secs, _ret) \
if (NULL != MONITORING_GLOBAL_INTERFACE) { \
AmArg di_args; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(name)); \
di_args.push(AmArg(secs)); \
MONITORING_GLOBAL_INTERFACE->invoke("getCount", di_args, _ret); \
} \
#define MONITORING_GET_COUNT(type, name, _ret) \
MONITORING_GET_COUNT_SEC(type, name, 1, _ret)
#define MONITORING_GET_ALL_COUNTS_SEC_NOW(type, secs, _now, _ret) \
if (NULL != MONITORING_GLOBAL_INTERFACE) { \
AmArg di_args; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(secs)); \
di_args.push(AmArg(ArgBlob((const char*)&_now, sizeof(_now)))); \
MONITORING_GLOBAL_INTERFACE->invoke("getAllCounts", di_args, _ret); \
}
#define MONITORING_GET_ALL_COUNTS_SEC(type, secs, _ret) \
if (NULL != MONITORING_GLOBAL_INTERFACE) { \
AmArg di_args; \
di_args.push(AmArg(type)); \
di_args.push(AmArg(secs)); \
MONITORING_GLOBAL_INTERFACE->invoke("getAllCounts", di_args, _ret); \
} \
#define MONITORING_GET_ALL_COUNTS(type, _ret) \
MONITORING_GET_ALL_COUNTS_SEC(type, 1, _ret)
#define MONITORING_MARK_FINISHED(callid) \
if (NULL != AmSessionContainer::monitoring_di) { \
AmArg di_args,ret; \
di_args.push(AmArg(callid)); \
AmSessionContainer::monitoring_di->invoke("markFinished", di_args, ret); \
} \
// it is always using AmSessionContainer::monitoring_di, thus these should
// not be necessary in apps
#define _MONITORING_DECLARE_INTERFACE(MOD) \
AmDynInvoke* MOD::monitoring_di = 0; \
#define _MONITORING_DEFINE_INTERFACE \
static AmDynInvoke* monitoring_di; \
#define MONITORING_GLOBAL_INTERFACE \
AmSessionContainer::monitoring_di
#define _MONITORING_INIT \
AmDynInvokeFactory* monitoring_fact= AmPlugIn::instance()->getFactory4Di("monitoring"); \
if(!monitoring_fact) { \
INFO("monitoring module not loaded, monitoring disabled\n"); \
} else { \
monitoring_di = monitoring_fact->getInstance(); \
assert(monitoring_di); \
INFO("monitoring enabled\n"); \
} \
#else
#define _MONITORING_DECLARE_INTERFACE(MOD)
#define _MONITORING_DEFINE_INTERFACE
#define _MONITORING_INIT
#define MONITORING_LOG(callid, property, value)
#define MONITORING_LOG2(callid, prop1, val1, prop2, val2)
#define MONITORING_LOG3(callid, prop1, val1, prop2, val2, prop3, val3)
#define MONITORING_LOG4(callid, prop1, val1, prop2, val2, prop3, val3, prop4, val4)
#define MONITORING_LOG5(callid, prop1, val1, prop2, val2, prop3, val3, prop4, val4, prop5, val5)
#define MONITORING_LOG_ADD(callid, property, value)
#define MONITORING_MARK_FINISHED(callid)
#endif
#endif