diff options
Diffstat (limited to 'epan/tvbuff_composite.c')
-rw-r--r-- | epan/tvbuff_composite.c | 89 |
1 files changed, 43 insertions, 46 deletions
diff --git a/epan/tvbuff_composite.c b/epan/tvbuff_composite.c index 620b8d27..e483d6ba 100644 --- a/epan/tvbuff_composite.c +++ b/epan/tvbuff_composite.c @@ -16,13 +16,13 @@ #include "proto.h" /* XXX - only used for DISSECTOR_ASSERT, probably a new header file? */ typedef struct { - GSList *tvbs; + GQueue *tvbs; /* Used for quick testing to see if this * is the tvbuff that a COMPOSITE is * interested in. */ - guint *start_offsets; - guint *end_offsets; + unsigned *start_offsets; + unsigned *end_offsets; } tvb_comp_t; @@ -38,40 +38,39 @@ composite_free(tvbuff_t *tvb) struct tvb_composite *composite_tvb = (struct tvb_composite *) tvb; tvb_comp_t *composite = &composite_tvb->composite; - g_slist_free(composite->tvbs); + g_queue_free(composite->tvbs); g_free(composite->start_offsets); g_free(composite->end_offsets); - g_free((gpointer)tvb->real_data); + g_free((void *)tvb->real_data); } -static guint -composite_offset(const tvbuff_t *tvb _U_, const guint counter) +static unsigned +composite_offset(const tvbuff_t *tvb _U_, const unsigned counter) { return counter; } -static const guint8* -composite_get_ptr(tvbuff_t *tvb, guint abs_offset, guint abs_length) +static const uint8_t* +composite_get_ptr(tvbuff_t *tvb, unsigned abs_offset, unsigned abs_length) { struct tvb_composite *composite_tvb = (struct tvb_composite *) tvb; - guint i, num_members; + unsigned i; tvb_comp_t *composite; tvbuff_t *member_tvb = NULL; - guint member_offset; - GSList *slist; + unsigned member_offset; /* DISSECTOR_ASSERT(tvb->ops == &tvb_composite_ops); */ /* Maybe the range specified by offset/length * is contiguous inside one of the member tvbuffs */ composite = &composite_tvb->composite; - num_members = g_slist_length(composite->tvbs); + GList *item = (GList*)composite->tvbs->head; - for (i = 0; i < num_members; i++) { + + for (i = 0; i < g_queue_get_length(composite->tvbs); i++, item=item->next) { if (abs_offset <= composite->end_offsets[i]) { - slist = g_slist_nth(composite->tvbs, i); - member_tvb = (tvbuff_t *)slist->data; + member_tvb = (tvbuff_t *)item->data; break; } } @@ -95,7 +94,7 @@ composite_get_ptr(tvbuff_t *tvb, guint abs_offset, guint abs_length) /* Use a temporary variable as tvb_memcpy is also checking tvb->real_data pointer */ void *real_data = g_malloc(tvb->length); tvb_memcpy(tvb, real_data, 0, tvb->length); - tvb->real_data = (const guint8 *)real_data; + tvb->real_data = (const uint8_t *)real_data; return tvb->real_data + abs_offset; } @@ -103,28 +102,26 @@ composite_get_ptr(tvbuff_t *tvb, guint abs_offset, guint abs_length) } static void * -composite_memcpy(tvbuff_t *tvb, void* _target, guint abs_offset, guint abs_length) +composite_memcpy(tvbuff_t *tvb, void* _target, unsigned abs_offset, unsigned abs_length) { struct tvb_composite *composite_tvb = (struct tvb_composite *) tvb; - guint8 *target = (guint8 *) _target; + uint8_t *target = (uint8_t *) _target; - guint i, num_members; + unsigned i; tvb_comp_t *composite; tvbuff_t *member_tvb = NULL; - guint member_offset, member_length; - GSList *slist; + unsigned member_offset, member_length; /* DISSECTOR_ASSERT(tvb->ops == &tvb_composite_ops); */ /* Maybe the range specified by offset/length * is contiguous inside one of the member tvbuffs */ composite = &composite_tvb->composite; - num_members = g_slist_length(composite->tvbs); - for (i = 0; i < num_members; i++) { + GList *item = (GList*)composite->tvbs->head; + for (i = 0; i < g_queue_get_length(composite->tvbs); i++, item=item->next) { if (abs_offset <= composite->end_offsets[i]) { - slist = g_slist_nth(composite->tvbs, i); - member_tvb = (tvbuff_t *)slist->data; + member_tvb = (tvbuff_t *)item->data; break; } } @@ -174,8 +171,8 @@ static const struct tvb_ops tvb_composite_ops = { composite_offset, /* offset */ composite_get_ptr, /* get_ptr */ composite_memcpy, /* memcpy */ - NULL, /* find_guint8 XXX */ - NULL, /* pbrk_guint8 XXX */ + NULL, /* find_uint8 XXX */ + NULL, /* pbrk_uint8 XXX */ NULL, /* clone */ }; @@ -198,7 +195,7 @@ tvb_new_composite(void) struct tvb_composite *composite_tvb = (struct tvb_composite *) tvb; tvb_comp_t *composite = &composite_tvb->composite; - composite->tvbs = NULL; + composite->tvbs = g_queue_new(); composite->start_offsets = NULL; composite->end_offsets = NULL; @@ -219,11 +216,11 @@ tvb_composite_append(tvbuff_t *tvb, tvbuff_t *member) */ if (member && member->length) { composite = &composite_tvb->composite; - composite->tvbs = g_slist_append(composite->tvbs, member); + g_queue_push_tail(composite->tvbs, member); /* Attach the composite TVB to the first TVB only. */ - if (!composite->tvbs->next) { - tvb_add_to_chain((tvbuff_t *)composite->tvbs->data, tvb); + if (g_queue_get_length(composite->tvbs) == 1) { + tvb_add_to_chain((tvbuff_t *)g_queue_peek_head(composite->tvbs), tvb); } } } @@ -242,11 +239,11 @@ tvb_composite_prepend(tvbuff_t *tvb, tvbuff_t *member) */ if (member && member->length) { composite = &composite_tvb->composite; - composite->tvbs = g_slist_prepend(composite->tvbs, member); + g_queue_push_head(composite->tvbs, member); /* Attach the composite TVB to the first TVB only. */ - if (!composite->tvbs->next) { - tvb_add_to_chain((tvbuff_t *)composite->tvbs->data, tvb); + if (g_queue_get_length(composite->tvbs) == 1) { + tvb_add_to_chain((tvbuff_t *)g_queue_peek_head(composite->tvbs), tvb); } } } @@ -255,11 +252,11 @@ void tvb_composite_finalize(tvbuff_t *tvb) { struct tvb_composite *composite_tvb = (struct tvb_composite *) tvb; - GSList *slist; - guint num_members; + + unsigned num_members; tvbuff_t *member_tvb; tvb_comp_t *composite; - int i = 0; + unsigned i; DISSECTOR_ASSERT(tvb && !tvb->initialized); DISSECTOR_ASSERT(tvb->ops == &tvb_composite_ops); @@ -268,7 +265,8 @@ tvb_composite_finalize(tvbuff_t *tvb) DISSECTOR_ASSERT(tvb->contained_length == 0); composite = &composite_tvb->composite; - num_members = g_slist_length(composite->tvbs); + + num_members = g_queue_get_length(composite->tvbs); /* Dissectors should not create composite TVBs if they're not going to * put at least one TVB in them. @@ -276,21 +274,20 @@ tvb_composite_finalize(tvbuff_t *tvb) */ DISSECTOR_ASSERT(num_members); - composite->start_offsets = g_new(guint, num_members); - composite->end_offsets = g_new(guint, num_members); + composite->start_offsets = g_new(unsigned, num_members); + composite->end_offsets = g_new(unsigned, num_members); - for (slist = composite->tvbs; slist != NULL; slist = slist->next) { - DISSECTOR_ASSERT((guint) i < num_members); - member_tvb = (tvbuff_t *)slist->data; + GList *item = (GList*)composite->tvbs->head; + for (i=0; i < num_members; i++, item=item->next) { + member_tvb = (tvbuff_t *)item->data; composite->start_offsets[i] = tvb->length; tvb->length += member_tvb->length; tvb->reported_length += member_tvb->reported_length; tvb->contained_length += member_tvb->contained_length; composite->end_offsets[i] = tvb->length - 1; - i++; } - tvb->initialized = TRUE; + tvb->initialized = true; tvb->ds_tvb = tvb; } |