/* This file is part of libcapwap. libcapwap is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. libcapwap is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Foobar. If not, see . */ #include #include #include #include #include "cw_log.h" #include "capwap.h" static void cw_log_debug0_(const char *format, ...) { if (cw_log_debug_level<0) return; va_list args; va_start(args, format); cw_vlog_(LOG_DEBUG,format,args); va_end(args); closelog(); } static void cw_log_debug1_(const char *format, ...) { if (cw_log_debug_level<1) return; va_list args; va_start(args, format); cw_vlog_(LOG_DEBUG,format,args); va_end(args); closelog(); } static void cw_log_debug2_(const char *format, ...) { if (cw_log_debug_level<2) return; va_list args; va_start(args, format); cw_vlog_(LOG_DEBUG,format,args); va_end(args); closelog(); } int cw_log_debug_dump_(int level,const uint8_t * data, int len,const char * format, ...) { int maxtlen=2048; int i; int rowlen = CW_LOG_DUMP_ROW_LEN; int rows = len/rowlen; int tlen=0; char * dst = malloc(len*3+(rows*2) + 8+maxtlen); if ( !dst ) return 0; if (format != NULL){ va_list args; va_start(args,format); tlen = vsnprintf(dst,maxtlen,format,args); va_end(args); } if (len%CW_LOG_DUMP_ROW_LEN) rows++; char * pdst=dst+tlen; sprintf(pdst,"\n\t"); pdst+=2; for (i=0; i0x80) c='.'; *ascdst=c; ascdst++; } pdst+=3; if ((i+1)%rowlen==0){ int l; if (cw_dbg_opt_detail & DBG_DETAIL_ASC_DMP){ *ascdst=0; l=sprintf(pdst," | %s\n\t",asc_buffer); ascdst=asc_buffer; } else{ l=sprintf(pdst,"\n\t"); } pdst+=l; } } if (cw_dbg_opt_detail & DBG_DETAIL_ASC_DMP){ *ascdst=0; if (strlen(asc_buffer)) pdst+=sprintf(pdst," | %s",asc_buffer); } if (cw_dbg_opt_detail & DBG_DETAIL_LINE_NUMBERS) cw_log(LOG_DEBUG,"%s:%d: %s",file,line,dst); else cw_log(LOG_DEBUG,dst); free (dst); return; } void (*cw_log_debug_cbs[])(const char * fromat, ...) = { cw_log_debug0_, cw_log_debug1_, cw_log_debug2_ }; void cw_dbg_msgelem_(int msg, int msgelem, const uint8_t *msgbuf,int len) { if (!cw_dbg_is_level(DBG_CW_MSGELEM)) return; /* char buf[250]; sprintf(buf,"Reading %s msgelem, type=%d (%d), len=%d", cw_msgtostr(msg), msgelem, cw_msgelemtostr(msg)); */ if (!cw_dbg_is_level(DBG_CW_MSGELEM_DMP)) cw_dbg(DBG_CW_MSGELEM,"Reading %s msgelem, type=%d (%s), len=%d", cw_msgtostr(msg), msgelem, cw_msgelemtostr(msgelem), len); else cw_dbg_dmp(DBG_CW_MSGELEM,msgbuf,len,"Reading %s msgelem, type=%d (%s), len=%d\n\t Dump ...", cw_msgtostr(msg), msgelem, cw_msgelemtostr(msgelem), len); } //cw_dbg(DBG_CW_MSGELEM,"Process discovery req msgelem, type=%d (%s), len=%d",type,cw_msgelemtostr(type),len); //cw_dbg_dmp(DBG_CW_MSGELEM_DMP,msgelem,len,"Dump for msgelem ...");