X-Git-Url: http://git.samba.org/samba.git/?a=blobdiff_plain;f=tap-h225counter.c;h=2f4b6e3af872810511b831aa3225637657b75d67;hb=55783f9485f6636470613aa2275200ebef1c9d7f;hp=35e83b5628925f2d9db05332ee218fb60b3c5e69;hpb=e363d0992ef6e2edee5c01d3f75a7a609947f9ad;p=obnox%2Fwireshark%2Fwip.git diff --git a/tap-h225counter.c b/tap-h225counter.c index 35e83b5628..2f4b6e3af8 100644 --- a/tap-h225counter.c +++ b/tap-h225counter.c @@ -1,11 +1,11 @@ /* tap_h225counter.c - * h225 message counter for ethereal + * h225 message counter for wireshark * Copyright 2003 Lars Roland * * $Id$ * - * Ethereal - Network traffic analyzer - * By Gerald Combs + * Wireshark - Network traffic analyzer + * By Gerald Combs * Copyright 1998 Gerald Combs * * This program is free software; you can redistribute it and/or @@ -23,10 +23,6 @@ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ -/* With MSVC and a libethereal.dll this file needs to import some variables - in a special way. Therefore _NEED_VAR_IMPORT_ is defined. */ -#define _NEED_VAR_IMPORT_ - #ifdef HAVE_CONFIG_H # include "config.h" #endif @@ -38,8 +34,10 @@ #endif #include +#include "epan/packet.h" #include "epan/packet_info.h" #include +#include #include "epan/value_string.h" #include "register.h" #include @@ -87,50 +85,11 @@ static void h225counter_reset(void *phs) { h225counter_t *hs=(h225counter_t *)phs; - int i; + char *save_filter = hs->filter; - for(i=0;i<=RAS_MSG_TYPES;i++) { - hs->ras_msg[i] = 0; - } - for(i=0;i<=CS_MSG_TYPES;i++) { - hs->cs_msg[i] = 0; - } - for(i=0;i<=GRJ_REASONS;i++) { - hs->grj_reason[i] = 0; - } - for(i=0;i<=RRJ_REASONS;i++) { - hs->rrj_reason[i] = 0; - } - for(i=0;i<=URQ_REASONS;i++) { - hs->urq_reason[i] = 0; - } - for(i=0;i<=URJ_REASONS;i++) { - hs->urj_reason[i] = 0; - } - for(i=0;i<=ARJ_REASONS;i++) { - hs->arj_reason[i] = 0; - } - for(i=0;i<=BRJ_REASONS;i++) { - hs->brj_reason[i] = 0; - } - for(i=0;i<=DRQ_REASONS;i++) { - hs->drq_reason[i] = 0; - } - for(i=0;i<=DRJ_REASONS;i++) { - hs->drj_reason[i] = 0; - } - for(i=0;i<=LRJ_REASONS;i++) { - hs->lrj_reason[i] = 0; - } - for(i=0;i<=IRQNAK_REASONS;i++) { - hs->irqnak_reason[i] = 0; - } - for(i=0;i<=REL_CMP_REASONS;i++) { - hs->rel_cmp_reason[i] = 0; - } - for(i=0;i<=FACILITY_REASONS;i++) { - hs->facility_reason[i] = 0; - } + memset(hs, 0, sizeof(h225counter_t)); + + hs->filter = save_filter; } static int @@ -266,7 +225,6 @@ h225counter_packet(void *phs, packet_info *pinfo _U_, epan_dissect_t *edt _U_, c default: return 0; - break; } return 1; @@ -283,7 +241,7 @@ h225counter_draw(void *phs) printf("RAS-Messages:\n"); for(i=0;i<=RAS_MSG_TYPES;i++) { if(hs->ras_msg[i]!=0) { - printf(" %s : %u\n", val_to_str(i,RasMessage_vals,"unknown ras-messages "), hs->ras_msg[i]); + printf(" %s : %u\n", val_to_str(i,h225_RasMessage_vals,"unknown ras-messages "), hs->ras_msg[i]); /* reason counter */ switch(i) { case 2: /* GRJ */ @@ -370,7 +328,7 @@ h225counter_draw(void *phs) case 5: /* ReleaseComplete */ for(j=0;j<=REL_CMP_REASONS;j++) { if(hs->rel_cmp_reason[j]!=0) { - printf(" %s : %u\n", val_to_str(j,ReleaseCompleteReason_vals,"unknown reason "), hs->rel_cmp_reason[j]); + printf(" %s : %u\n", val_to_str(j,h225_ReleaseCompleteReason_vals,"unknown reason "), hs->rel_cmp_reason[j]); } } break; @@ -391,22 +349,20 @@ h225counter_draw(void *phs) static void -h225counter_init(char *optarg) +h225counter_init(const char *optarg, void* userdata _U_) { h225counter_t *hs; - char *filter=NULL; + const char *filter=NULL; GString *error_string; if(!strncmp(optarg,"h225,counter,",13)){ filter=optarg+13; } else { - filter=g_malloc(1); - *filter='\0'; + filter=""; } hs = g_malloc(sizeof(h225counter_t)); - hs->filter=g_malloc(strlen(filter)+1); - strcpy(hs->filter, filter); + hs->filter=g_strdup(filter); h225counter_reset(hs); @@ -416,7 +372,7 @@ h225counter_init(char *optarg) g_free(hs->filter); g_free(hs); - fprintf(stderr, "tethereal: Couldn't register h225,counter tap: %s\n", + fprintf(stderr, "tshark: Couldn't register h225,counter tap: %s\n", error_string->str); g_string_free(error_string, TRUE); exit(1); @@ -427,5 +383,5 @@ h225counter_init(char *optarg) void register_tap_listener_h225counter(void) { - register_ethereal_tap("h225,counter", h225counter_init); + register_stat_cmd_arg("h225,counter", h225counter_init,NULL); }