/* tap_camelcounter.c
* camel message counter for tshark
* Copyright 2006 Florent DROUIN
+ *
+ * $Id$
+ *
* This part of code is extracted from tap-h225counter.c from Lars Roland
*
* Wireshark - Network traffic analyzer
#endif
#include <string.h>
-#include "epan/proto.h"
+#include "epan/packet.h"
#include "epan/packet_info.h"
#include "epan/tap.h"
#include "epan/value_string.h"
-#include "register.h"
#include "epan/stat_cmd_args.h"
#include "epan/asn1.h"
#include "epan/camel-persistentdata.h"
/* used to keep track of the statistics for an entire program interface */
struct camelcounter_t {
- char *filter;
+ char *filter;
guint32 camel_msg[camel_MAX_NUM_OPR_CODES];
};
static int camelcounter_packet(void *phs,
packet_info *pinfo _U_,
- epan_dissect_t *edt _U_,
+ epan_dissect_t *edt _U_,
const void *phi)
{
struct camelcounter_t * p_counter =(struct camelcounter_t *)phs;
const struct camelsrt_info_t * pi=phi;
if (pi->opcode != 255)
p_counter->camel_msg[pi->opcode]++;
-
+
return 1;
}
if(p_counter->camel_msg[i]!=0) {
printf("%30s ", val_to_str(i,camel_opr_code_strings,"Unknown message "));
printf("%6d\n", p_counter->camel_msg[i]);
- }
+ }
} /* Message Type */
printf("------------------------------------------\n");
}
static void camelcounter_init(const char *optarg, void* userdata _U_)
{
struct camelcounter_t *p_camelcounter;
- const char *filter=NULL;
- const char *emptyfilter="";
GString *error_string;
- if(!strncmp(optarg,"camel,counter,",13)){
- filter=optarg+13;
- } else {
- filter=NULL;
- }
-
p_camelcounter = g_malloc(sizeof(struct camelcounter_t));
- if(filter){
- p_camelcounter->filter=g_malloc(strlen(filter)+1);
- strcpy(p_camelcounter->filter,filter);
+ if(!strncmp(optarg,"camel,counter,",13)){
+ p_camelcounter->filter=g_strdup(optarg+13);
} else {
p_camelcounter->filter=NULL;
}
-
+
camelcounter_reset(p_camelcounter);
- if (filter) {
- error_string=register_tap_listener("CAMEL",
- p_camelcounter,
- filter,
- NULL,
- camelcounter_packet,
- camelcounter_draw);
- } else {
- error_string=register_tap_listener("CAMEL",
- p_camelcounter,
- emptyfilter,
- NULL,
- camelcounter_packet,
- camelcounter_draw);
- }
+ error_string=register_tap_listener("CAMEL",
+ p_camelcounter,
+ p_camelcounter->filter,
+ 0,
+ NULL,
+ camelcounter_packet,
+ camelcounter_draw);
if(error_string){
/* error, we failed to attach to the tap. clean up */