From: Jani Nikula Date: Thu, 12 Apr 2012 20:57:39 +0000 (+0300) Subject: lib: work around talloc_steal usage from C++ code X-Git-Tag: 0.13_rc1~75 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=de0557477d908be26615e8fda9f5eb62bed68b65;p=notmuch.git lib: work around talloc_steal usage from C++ code Implicit typecast from 'void *' to 'T *' is okay in C, but not in C++. In talloc_steal, an explicit cast is provided for type safety in some GCC versions. Otherwise, a cast is required. Provide a template function for this to maintain type safety, and redefine talloc_steal to use it. The template must be outside the extern "C" block (NOTMUCH_BEGIN_DECLS and NOTMUCH_END_DECLS), but keep it within the GCC visibility #pragma. No functional changes, apart from making the library build with compilers other than recent GCC. Signed-off-by: Jani Nikula --- diff --git a/lib/notmuch-private.h b/lib/notmuch-private.h index ea836f72..3886e0ca 100644 --- a/lib/notmuch-private.h +++ b/lib/notmuch-private.h @@ -495,8 +495,26 @@ notmuch_filenames_t * _notmuch_filenames_create (const void *ctx, notmuch_string_list_t *list); -#pragma GCC visibility pop - NOTMUCH_END_DECLS +#ifdef __cplusplus +/* Implicit typecast from 'void *' to 'T *' is okay in C, but not in + * C++. In talloc_steal, an explicit cast is provided for type safety + * in some GCC versions. Otherwise, a cast is required. Provide a + * template function for this to maintain type safety, and redefine + * talloc_steal to use it. + */ +#if !(__GNUC__ >= 3) +template T * +_notmuch_talloc_steal (const void *new_ctx, const T *ptr) +{ + return static_cast (talloc_steal (new_ctx, ptr)); +} +#undef talloc_steal +#define talloc_steal _notmuch_talloc_steal +#endif +#endif + +#pragma GCC visibility pop + #endif