Merge in fixes for SASL.
[m6w6/libmemcached] / clients / memflush.cc
index 848bc1e7d1677937d620afd91fc9a1171b6bc35a..b19c286067c627801ff853fb6f0368c95e5c5000 100644 (file)
  */
 #include "config.h"
 
-#include <stdio.h>
-#include <unistd.h>
-#include <string.h>
+#include <cstdio>
+#include <cstring>
 #include <getopt.h>
+#include <iostream>
+#include <unistd.h>
+
 #include <libmemcached/memcached.h>
 #include "client_options.h"
 #include "utilities.h"
@@ -60,6 +62,14 @@ int main(int argc, char *argv[])
   memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL,
                          (uint64_t) opt_binary);
 
+  if (opt_username and LIBMEMCACHED_WITH_SASL_SUPPORT == 0)
+  {
+    memcached_free(memc);
+    std::cerr << "--username was supplied, but binary was not built with SASL support." << std::endl;
+    return EXIT_FAILURE;
+  }
+
+
   if (!initialize_sasl(memc, opt_username, opt_passwd))
   {
     memcached_free(memc);