mirror of
https://gitlab.xiph.org/xiph/icecast-common.git
synced 2025-01-03 14:56:36 -05:00
Fix: Corrected bugs related to incorrect check for transparent unions
This commit is contained in:
parent
68332f291f
commit
4a9dd94b07
@ -97,8 +97,9 @@ int igloo_list_iterator_rewind(igloo_list_iterator_t *iterat
|
|||||||
do { \
|
do { \
|
||||||
igloo_list_iterator_storage_t __igloo_list_iterator_storage; \
|
igloo_list_iterator_storage_t __igloo_list_iterator_storage; \
|
||||||
igloo_list_iterator_t *__igloo_list_iterator = igloo_list_iterator_start((list), &__igloo_list_iterator_storage, sizeof(__igloo_list_iterator_storage)); \
|
igloo_list_iterator_t *__igloo_list_iterator = igloo_list_iterator_start((list), &__igloo_list_iterator_storage, sizeof(__igloo_list_iterator_storage)); \
|
||||||
|
igloo_ro_t __igloo_ret; \
|
||||||
type * var; \
|
type * var; \
|
||||||
for (; !igloo_RO_IS_NULL((var) = igloo_RO_TO_TYPE(igloo_list_iterator_next(__igloo_list_iterator),type));) { \
|
for (; !igloo_RO_IS_NULL(__igloo_ret = igloo_list_iterator_next(__igloo_list_iterator)) && ((var) = igloo_RO_TO_TYPE(__igloo_ret,type));) { \
|
||||||
code; \
|
code; \
|
||||||
igloo_ro_unref((var)); \
|
igloo_ro_unref((var)); \
|
||||||
} \
|
} \
|
||||||
|
@ -26,6 +26,7 @@ extern "C" {
|
|||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#include <igloo/config.h>
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
#include "thread.h"
|
#include "thread.h"
|
||||||
|
|
||||||
@ -88,11 +89,11 @@ struct igloo_ro_base_tag {
|
|||||||
int igloo_ro_new__return_zero(igloo_ro_t self, const igloo_ro_type_t *type, va_list ap);
|
int igloo_ro_new__return_zero(igloo_ro_t self, const igloo_ro_type_t *type, va_list ap);
|
||||||
/* ---[ END PRIVATE ]--- */
|
/* ---[ END PRIVATE ]--- */
|
||||||
|
|
||||||
#ifdef igloo_HAVE_TYPE_ATTRIBUTE_TRANSPARENT_UNION
|
#ifdef IGLOO_CTC_HAVE_TYPE_ATTRIBUTE_TRANSPARENT_UNION
|
||||||
#define igloo_RO__GETBASE(x) (((igloo_ro_t)(x)).subtype__igloo_ro_base_t)
|
#define igloo_RO__GETBASE(x) (((igloo_ro_t)(x)).subtype__igloo_ro_base_t)
|
||||||
#define igloo_RO_NULL ((igloo_ro_t)(igloo_ro_base_t*)NULL)
|
#define igloo_RO_NULL ((igloo_ro_t)(igloo_ro_base_t*)NULL)
|
||||||
#define igloo_RO_IS_NULL(x) (igloo_RO__GETBASE((x)) == NULL)
|
#define igloo_RO_IS_NULL(x) (igloo_RO__GETBASE((x)) == NULL)
|
||||||
#define igloo_RO_TO_TYPE(x,type) (igloo_RO_IS_VALID((x),type) ? NULL : ((igloo_ro_t)(x)).subtype__ ## type)
|
#define igloo_RO_TO_TYPE(x,type) (igloo_RO_IS_VALID((x),type) ? ((igloo_ro_t)(x)).subtype__ ## type : NULL)
|
||||||
#else
|
#else
|
||||||
#define igloo_RO__GETBASE(x) ((igloo_ro_base_t*)(x))
|
#define igloo_RO__GETBASE(x) ((igloo_ro_base_t*)(x))
|
||||||
#define igloo_RO_NULL NULL
|
#define igloo_RO_NULL NULL
|
||||||
|
@ -29,6 +29,8 @@ extern "C" {
|
|||||||
/* For size_t and ssize_t */
|
/* For size_t and ssize_t */
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#include <igloo/config.h>
|
||||||
|
|
||||||
/* Included in case is not yet included */
|
/* Included in case is not yet included */
|
||||||
#include "typedef.h"
|
#include "typedef.h"
|
||||||
|
|
||||||
@ -49,7 +51,7 @@ typedef struct igloo_reportxml_database_tag igloo_reportxml_database_t;
|
|||||||
typedef struct igloo_ro_base_tag igloo_ro_base_t;
|
typedef struct igloo_ro_base_tag igloo_ro_base_t;
|
||||||
igloo_RO_FORWARD_TYPE(igloo_ro_base_t);
|
igloo_RO_FORWARD_TYPE(igloo_ro_base_t);
|
||||||
|
|
||||||
#ifdef igloo_HAVE_TYPE_ATTRIBUTE_TRANSPARENT_UNION
|
#ifdef IGLOO_CTC_HAVE_TYPE_ATTRIBUTE_TRANSPARENT_UNION
|
||||||
typedef union __attribute__ ((__transparent_union__)) {
|
typedef union __attribute__ ((__transparent_union__)) {
|
||||||
/* Those are libigloo's own types */
|
/* Those are libigloo's own types */
|
||||||
igloo_RO_TYPE(igloo_ro_base_t)
|
igloo_RO_TYPE(igloo_ro_base_t)
|
||||||
|
@ -72,5 +72,5 @@ igloo_ro_t igloo_initialize(void)
|
|||||||
|
|
||||||
igloo_initialize__refc++;
|
igloo_initialize__refc++;
|
||||||
|
|
||||||
return ret;
|
return (igloo_ro_t)ret;
|
||||||
}
|
}
|
||||||
|
@ -1137,7 +1137,7 @@ static igloo_reportxml_node_t * __reportxml_database_build_node_ext(igloo_r
|
|||||||
}
|
}
|
||||||
|
|
||||||
igloo_thread_mutex_lock(&(db->lock));
|
igloo_thread_mutex_lock(&(db->lock));
|
||||||
if (igloo_avl_get_by_key(db->definitions, igloo_RO_TO_TYPE(search, void *), (void**)&found) != 0) {
|
if (igloo_avl_get_by_key(db->definitions, (void*)search, (void**)&found) != 0) {
|
||||||
igloo_thread_mutex_unlock(&(db->lock));
|
igloo_thread_mutex_unlock(&(db->lock));
|
||||||
igloo_ro_unref(search);
|
igloo_ro_unref(search);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
5
src/ro.c
5
src/ro.c
@ -147,9 +147,8 @@ int igloo_ro_unref(igloo_ro_t self)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (base->refc > 1) {
|
||||||
base->refc--;
|
base->refc--;
|
||||||
|
|
||||||
if (base->refc) {
|
|
||||||
igloo_thread_mutex_unlock(&(base->lock));
|
igloo_thread_mutex_unlock(&(base->lock));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -157,6 +156,8 @@ int igloo_ro_unref(igloo_ro_t self)
|
|||||||
if (base->type->type_freecb)
|
if (base->type->type_freecb)
|
||||||
base->type->type_freecb(self);
|
base->type->type_freecb(self);
|
||||||
|
|
||||||
|
base->refc--;
|
||||||
|
|
||||||
igloo_ro_unref(base->associated);
|
igloo_ro_unref(base->associated);
|
||||||
|
|
||||||
if (base->name)
|
if (base->name)
|
||||||
|
@ -152,21 +152,21 @@ static void test_sizes(void)
|
|||||||
{
|
{
|
||||||
igloo_ro_t a;
|
igloo_ro_t a;
|
||||||
|
|
||||||
a = igloo_ro_new(ctest_test_type_a_t);
|
a = (igloo_ro_t)igloo_ro_new(ctest_test_type_a_t);
|
||||||
ctest_test("refobject created with size=sizeof(igloo_ro_base_t) + 1024", !igloo_RO_IS_NULL(a));
|
ctest_test("refobject created with size=sizeof(igloo_ro_base_t) + 1024", !igloo_RO_IS_NULL(a));
|
||||||
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
||||||
|
|
||||||
a = igloo_ro_new(ctest_test_type_b_t);
|
a = (igloo_ro_t)igloo_ro_new(ctest_test_type_b_t);
|
||||||
ctest_test("refobject created with size=sizeof(igloo_ro_base_t) + 131072", !igloo_RO_IS_NULL(a));
|
ctest_test("refobject created with size=sizeof(igloo_ro_base_t) + 131072", !igloo_RO_IS_NULL(a));
|
||||||
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
||||||
|
|
||||||
a = igloo_ro_new(ctest_test_type_c_t);
|
a = (igloo_ro_t)igloo_ro_new(ctest_test_type_c_t);
|
||||||
ctest_test("refobject created with size=sizeof(igloo_ro_base_t) - 1", igloo_RO_IS_NULL(a));
|
ctest_test("refobject created with size=sizeof(igloo_ro_base_t) - 1", igloo_RO_IS_NULL(a));
|
||||||
if (!igloo_RO_IS_NULL(a)) {
|
if (!igloo_RO_IS_NULL(a)) {
|
||||||
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
a = igloo_ro_new(ctest_test_type_d_t);
|
a = (igloo_ro_t)igloo_ro_new(ctest_test_type_d_t);
|
||||||
ctest_test("refobject created with size=0", igloo_RO_IS_NULL(a));
|
ctest_test("refobject created with size=0", igloo_RO_IS_NULL(a));
|
||||||
if (!igloo_RO_IS_NULL(a)) {
|
if (!igloo_RO_IS_NULL(a)) {
|
||||||
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
ctest_test("un-referenced", igloo_ro_unref(a) == 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user