X-Git-Url: http://git.efficios.com/?p=lttng-tools.git;a=blobdiff_plain;f=src%2Fcommon%2Fdynamic-array.c;h=bea903cafeae2a115b1fc1816345a0d50017dc8f;hp=094e269a4fe6e9d8245f517ab1d9e692a5ba8d94;hb=74465ffbb5ead0a3d7ba6342e7baf16f4fa662f9;hpb=35ab25e536fda26b8e079726cd2ce9d552f25bc8 diff --git a/src/common/dynamic-array.c b/src/common/dynamic-array.c index 094e269a4..bea903caf 100644 --- a/src/common/dynamic-array.c +++ b/src/common/dynamic-array.c @@ -87,6 +87,22 @@ void lttng_dynamic_array_reset(struct lttng_dynamic_array *array) array->size = 0; } +LTTNG_HIDDEN +void lttng_dynamic_array_clear(struct lttng_dynamic_array *array) +{ + if (array->destructor) { + size_t i; + + for (i = 0; i < lttng_dynamic_array_get_count(array); i++) { + array->destructor(lttng_dynamic_array_get_element(array, + i)); + } + } + + lttng_dynamic_buffer_set_size(&array->buffer, 0); + array->size = 0; +} + LTTNG_HIDDEN void lttng_dynamic_pointer_array_init( struct lttng_dynamic_pointer_array *array, @@ -138,3 +154,28 @@ void lttng_dynamic_pointer_array_reset( } lttng_dynamic_array_reset(&array->array); } + +LTTNG_HIDDEN +void lttng_dynamic_pointer_array_clear( + struct lttng_dynamic_pointer_array *array) +{ + const lttng_dynamic_array_element_destructor destructor = + array->array.destructor; + + /* + * Prevent the destructor from being used by the underlying + * dynamic array. + */ + array->array.destructor = NULL; + if (destructor) { + size_t i, count = lttng_dynamic_pointer_array_get_count(array); + + for (i = 0; i < count; i++) { + void *ptr = lttng_dynamic_pointer_array_get_pointer( + array, i); + destructor(ptr); + } + } + lttng_dynamic_array_clear(&array->array); + array->array.destructor = destructor; +}