Justus Winter <jus...@gnupg.org> skribis:

> +#define Mach_port_check(NAME)                                           \
> +  void _Mach_port_check_##NAME(char *_unused[] __attribute__ ((unused))) \
> +  {                                                                     \
> +  if (MACH_PORT_VALID (NAME))                                           \
> +    __print_fail_backtrace (#NAME " leaked",                            \
> +                            __FILE__, __LINE__, "Port leak detector");  \
> +  }                                                                     \
> +  char _Mach_port_check_x_##NAME[0]                                     \
> +  __attribute__ ((unused, cleanup (_Mach_port_check_##NAME)))

I think writing a GCC plug-in that would automatically add a cleanup
handler to automatic variables of type ‘mach_port_t’ wouldn’t be
unreasonable.

Ludo’.


Reply via email to