X-Git-Url: https://git.liburcu.org/?a=blobdiff_plain;f=urcu%2Flist.h;h=f27ff7ba7900ddcf17ba9be95087d1bd4fee1c5f;hb=147485105cf7b5c8ea96d7f68df973b9c5a94e8e;hp=04dad80929ef1d6f2ec1a3adcd302d8f2f962533;hpb=7865436286d8e1fe13d3087846f32a218b395e22;p=urcu.git diff --git a/urcu/list.h b/urcu/list.h index 04dad80..f27ff7b 100644 --- a/urcu/list.h +++ b/urcu/list.h @@ -154,20 +154,20 @@ cds_list_splice (struct cds_list_head *add, struct cds_list_head *head) pos = p, p = pos->prev) #define cds_list_for_each_entry(pos, head, member) \ - for (pos = cds_list_entry((head)->next, typeof(*pos), member); \ + for (pos = cds_list_entry((head)->next, __typeof__(*pos), member); \ &pos->member != (head); \ - pos = cds_list_entry(pos->member.next, typeof(*pos), member)) + pos = cds_list_entry(pos->member.next, __typeof__(*pos), member)) #define cds_list_for_each_entry_reverse(pos, head, member) \ - for (pos = cds_list_entry((head)->prev, typeof(*pos), member); \ + for (pos = cds_list_entry((head)->prev, __typeof__(*pos), member); \ &pos->member != (head); \ - pos = cds_list_entry(pos->member.prev, typeof(*pos), member)) + pos = cds_list_entry(pos->member.prev, __typeof__(*pos), member)) #define cds_list_for_each_entry_safe(pos, p, head, member) \ - for (pos = cds_list_entry((head)->next, typeof(*pos), member), \ - p = cds_list_entry(pos->member.next,typeof(*pos), member); \ + for (pos = cds_list_entry((head)->next, __typeof__(*pos), member), \ + p = cds_list_entry(pos->member.next, __typeof__(*pos), member); \ &pos->member != (head); \ - pos = p, p = cds_list_entry(pos->member.next, typeof(*pos), member)) + pos = p, p = cds_list_entry(pos->member.next, __typeof__(*pos), member)) static inline int cds_list_empty(struct cds_list_head *head) {