X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fhas.cc;h=9b26b96b675dab7d2fef408cdcf99e276553758c;hb=8926da4bfb40831308843eb75e7e665ad178eea8;hp=52e1d405b26f90a91e6f70c711c61332ba34dea0;hpb=1ec487c7ab72d33035f25a2164587d736998a10c;p=m6w6%2Flibmemcached diff --git a/libtest/has.cc b/libtest/has.cc index 52e1d405..9b26b96b 100644 --- a/libtest/has.cc +++ b/libtest/has.cc @@ -34,7 +34,7 @@ * */ -#include +#include "libtest/yatlcon.h" #include #include @@ -44,28 +44,34 @@ namespace libtest { bool has_libmemcached(void) { +#if defined(HAVE_LIBMEMCACHED) && HAVE_LIBMEMCACHED if (HAVE_LIBMEMCACHED) { return true; } +#endif return false; } bool has_libdrizzle(void) { +#if defined(HAVE_LIBDRIZZLE) && HAVE_LIBDRIZZLE if (HAVE_LIBDRIZZLE) { return true; } +#endif return false; } bool has_postgres_support(void) { - if (getenv("POSTGES_IS_RUNNING_AND_SETUP")) + char *getenv_ptr; + if (bool((getenv_ptr= getenv("POSTGES_IS_RUNNING_AND_SETUP")))) { + (void)(getenv_ptr); if (HAVE_LIBPQ) { return true; @@ -78,13 +84,16 @@ bool has_postgres_support(void) bool has_gearmand() { +#if defined(HAVE_GEARMAND_BINARY) && HAVE_GEARMAND_BINARY if (HAVE_GEARMAND_BINARY) { std::stringstream arg_buffer; - if (getenv("PWD")) + char *getenv_ptr; + if (bool((getenv_ptr= getenv("PWD"))) and + ((strcmp(GEARMAND_BINARY, "./gearmand/gearmand") == 0) or (strcmp(GEARMAND_BINARY, "gearmand/gearmand") == 0))) { - arg_buffer << getenv("PWD"); + arg_buffer << getenv_ptr; arg_buffer << "/"; } arg_buffer << GEARMAND_BINARY; @@ -94,12 +103,14 @@ bool has_gearmand() return true; } } +#endif return false; } bool has_drizzled() { +#if defined(HAVE_DRIZZLED_BINARY) && HAVE_DRIZZLED_BINARY if (HAVE_DRIZZLED_BINARY) { if (access(DRIZZLED_BINARY, X_OK) == 0) @@ -107,19 +118,38 @@ bool has_drizzled() return true; } } +#endif + + return false; +} + +bool has_mysqld() +{ +#if defined(HAVE_MYSQLD_BUILD) && HAVE_MYSQLD_BUILD + if (HAVE_MYSQLD_BUILD) + { + if (access(MYSQLD_BINARY, X_OK) == 0) + { + return true; + } + } +#endif return false; } bool has_memcached() { +#if defined(HAVE_MEMCACHED_BINARY) && HAVE_MEMCACHED_BINARY if (HAVE_MEMCACHED_BINARY) { std::stringstream arg_buffer; - if (getenv("PWD") and strcmp(MEMCACHED_BINARY, "memcached/memcached") == 0) + + char *getenv_ptr; + if (bool((getenv_ptr= getenv("PWD"))) and strcmp(MEMCACHED_BINARY, "memcached/memcached") == 0) { - arg_buffer << getenv("PWD"); + arg_buffer << getenv_ptr; arg_buffer << "/"; } arg_buffer << MEMCACHED_BINARY; @@ -129,12 +159,14 @@ bool has_memcached() return true; } } +#endif return false; } bool has_memcached_sasl() { +#if defined(HAVE_MEMCACHED_SASL_BINARY) && HAVE_MEMCACHED_SASL_BINARY if (HAVE_MEMCACHED_SASL_BINARY) { if (access(MEMCACHED_SASL_BINARY, X_OK) == 0) @@ -142,6 +174,7 @@ bool has_memcached_sasl() return true; } } +#endif return false; }