00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00035
00036
00037
00038
00039
00040
00041 #ifndef DEF_LOG_H
00042 #define DEF_LOG_H
00043
00044 #include <stdio.h>
00045 #include <stdarg.h>
00046
00047 typedef void (*RoMsgFunc)(char *format, va_list args) ;
00048 typedef void (*LogExitFunc)(void) ;
00049
00050 extern void log_registerExit(LogExitFunc f) ;
00051 extern void log_registerDie(RoMsgFunc f) ;
00052 extern void log_deregisterDie(RoMsgFunc f) ;
00053 extern void log_registerWarn(RoMsgFunc f) ;
00054 extern void log_deregisterWarn(RoMsgFunc f) ;
00055 extern void log_registerUsage(RoMsgFunc f) ;
00056 extern void log_deregisterUsage(RoMsgFunc f) ;
00057 extern void log_registerRomsg(RoMsgFunc f) ;
00058 extern void log_deregisterRomsg(RoMsgFunc f) ;
00059
00060 extern void die(char *format,...) ;
00061 extern void warn(char *format,...) ;
00062 extern void usage(char *format,...) ;
00063 extern void romsg(char *format,...) ;
00064
00065
00066 extern int log_debugLevel ;
00067 #define debugLevelSet(level) (log_debugLevel=(level))
00068 #define debugLevelGet() log_debugLevel
00069 #ifdef HLR_DEBUG_ON
00070 #define debugMsg(level,msg) {if (level<=debugLevelGet()) printf msg;}
00071 #else
00072 #define debugMsg(level,msg)
00073 #endif
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083 extern void warnAdd(char *source, char *msg) ;
00084 extern char *warnReport(void) ;
00085 extern void warnReset(void) ;
00086 extern void warnIterInit(void) ;
00087 extern int warnIterNext(char **source, char **msg) ;
00088 extern int warnCount(char *sourceStart, char *msgStart) ;
00089
00090
00091 extern void LogOpen(char *fname) ;
00092 extern void Log(char *format,...) ;
00093 extern void LogT(char *format,...) ;
00094 extern void LogClose (void) ;
00095 extern int LogOpened(void) ;
00096 extern void LogPrintTime(FILE *f) ;
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109 #ifdef HLR_ASSERT_OFF
00110 #define hlr_assert(truecondition,message) 1
00111 #else
00112 #define hlr_assert(truecondition,message) ((truecondition)?1:(die(message),0))
00113 #endif
00114
00115 #endif
00116