/* vim:expandtab:shiftwidth=2:tabstop=2:smarttab: * * Data Differential YATL (i.e. libtest) library * * Copyright (C) 2012-2013 Data Differential, http://datadifferential.com/ * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * * * The names of its contributors may not be used to endorse or * promote products derived from this software without specific prior * written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ #include "libtest/yatlcon.h" #include #include #include #include namespace libtest { #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wunreachable-code" bool has_libmemcached(void) { #if defined(HAVE_LIBMEMCACHED) && HAVE_LIBMEMCACHED if (HAVE_LIBMEMCACHED) { return true; } #endif return false; } #pragma GCC diagnostic pop bool has_libdrizzle(void) { #if defined(HAVE_LIBDRIZZLE) && HAVE_LIBDRIZZLE if (HAVE_LIBDRIZZLE) { return true; } #endif return false; } bool has_postgres_support(void) { char *getenv_ptr; if (bool((getenv_ptr= getenv("POSTGRES_IS_RUNNING_AND_SETUP")))) { (void)(getenv_ptr); if (HAVE_LIBPQ) { return true; } } return false; } bool has_gearmand() { #if defined(GEARMAND_BINARY) && defined(HAVE_GEARMAND_BINARY) && HAVE_GEARMAND_BINARY if (HAVE_GEARMAND_BINARY) { std::stringstream arg_buffer; 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_ptr; arg_buffer << "/"; } arg_buffer << GEARMAND_BINARY; if (access(arg_buffer.str().c_str(), X_OK) == 0) { return true; } } #endif return false; } bool has_drizzled() { #if defined(DRIZZLED_BINARY) && defined(HAVE_DRIZZLED_BINARY) && HAVE_DRIZZLED_BINARY && defined(HAVE_LIBMYSQL_BUILD) && HAVE_LIBMYSQL_BUILD { if (access(DRIZZLED_BINARY, X_OK) == 0) { return true; } } #endif return false; } bool has_mysqld() { #if defined(MYSQLD_BINARY) && defined(HAVE_MYSQLD_BUILD) && HAVE_MYSQLD_BUILD && defined(HAVE_LIBMYSQL_BUILD) && HAVE_LIBMYSQL_BUILD { if (access(MYSQLD_BINARY, X_OK) == 0) { return true; } } #endif return false; } static char memcached_binary_path[FILENAME_MAX +1]= { 0 }; static void initialize_memcached_binary_path() { memcached_binary_path[0]= 0; #if defined(MEMCACHED_BINARY) && defined(HAVE_MEMCACHED_BINARY) && HAVE_MEMCACHED_BINARY if (HAVE_MEMCACHED_BINARY) { std::stringstream arg_buffer; char *getenv_ptr; if (bool((getenv_ptr= getenv("PWD"))) and strcmp(MEMCACHED_BINARY, "memcached/memcached") == 0) { arg_buffer << getenv_ptr; arg_buffer << "/"; } arg_buffer << MEMCACHED_BINARY; if (access(arg_buffer.str().c_str(), X_OK) == 0) { strncpy(memcached_binary_path, arg_buffer.str().c_str(), FILENAME_MAX); } } #endif } static pthread_once_t memcached_binary_once= PTHREAD_ONCE_INIT; static void initialize_memcached_binary(void) { int ret; if ((ret= pthread_once(&memcached_binary_once, initialize_memcached_binary_path)) != 0) { FATAL(strerror(ret)); } } bool has_memcached() { initialize_memcached_binary(); if (memcached_binary_path[0] and (strlen(memcached_binary_path) > 0)) { return true; } return false; } const char* memcached_binary() { initialize_memcached_binary(); if (memcached_binary_path[0]) { return memcached_binary_path; } return NULL; } const char *gearmand_binary() { #if defined(GEARMAND_BINARY) return GEARMAND_BINARY; #else return NULL; #endif } const char *drizzled_binary() { #if defined(DRIZZLED_BINARY) return DRIZZLED_BINARY; #else return NULL; #endif } } // namespace libtest