From d3b49e3ec5524f2e16f96210f450ddb9f8f07070 Mon Sep 17 00:00:00 2001 From: OBATA Akio Date: Thu, 18 Apr 2019 17:25:48 +0900 Subject: [PATCH] Change to dclare `strlcat` and `strlcpy` conditionally They should be declared only for the case missing. Current prototype signatures should be for suppliment implementations in TDE core library. It may differ than platform builtin one, 3rd argment is `size_t', so it cause prototype mismatch for the case `size_t` != `unsigned long`. Signed-off-by: OBATA Akio --- ConfigureChecks.cmake | 3 +++ config.h.cmake | 17 ++++++++++++++++- 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/ConfigureChecks.cmake b/ConfigureChecks.cmake index 117d306b..4d5ad07a 100644 --- a/ConfigureChecks.cmake +++ b/ConfigureChecks.cmake @@ -45,3 +45,6 @@ if( WITH_SLP ) tde_message_fatal( "openslp is required, but was not found on your system" ) endif( ) endif( ) + +check_symbol_exists( strlcat "string.h" HAVE_STRLCAT_PROTO ) +check_symbol_exists( strlcpy "string.h" HAVE_STRLCPY_PROTO ) diff --git a/config.h.cmake b/config.h.cmake index 38def3f3..3bed93bc 100644 --- a/config.h.cmake +++ b/config.h.cmake @@ -62,9 +62,24 @@ // wifi #cmakedefine WITHOUT_ARTS 1 +/* Define if you have the strlcat prototype */ +#cmakedefine HAVE_STRLCAT_PROTO + +/* Define if you have the strlcpy prototype */ +#cmakedefine HAVE_STRLCPY_PROTO + +#if !defined(HAVE_STRLCAT_PROTO) #ifdef __cplusplus extern "C" { -unsigned long strlcpy(char*, const char*, unsigned long); unsigned long strlcat(char*, const char*, unsigned long); } #endif +#endif + +#if !defined(HAVE_STRLCPY_PROTO) +#ifdef __cplusplus +extern "C" { +unsigned long strlcpy(char*, const char*, unsigned long); +} +#endif +#endif