X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fmemcat.c;h=1ee024279620ac982066d865f2948d13992a3b8b;hb=b01ff6189633c1bf86f94065d2564810e6871869;hp=81c0a85d6167c40e0cc973a21be9d578f36a34d9;hpb=113160884d25c401dc352cfab093b5b7b1a4fde0;p=m6w6%2Flibmemcached diff --git a/src/memcat.c b/src/memcat.c index 81c0a85d..1ee02427 100644 --- a/src/memcat.c +++ b/src/memcat.c @@ -1,11 +1,15 @@ #include +#include +#include #include #include #include -#include "client_options.h" #include "utilities.h" +#define PROGRAM_NAME "memcat" +#define PROGRAM_DESCRIPTION "Cat a set of key values to stdout." + /* Prototypes */ void options_parse(int argc, char *argv[]); @@ -26,11 +30,19 @@ int main(int argc, char *argv[]) options_parse(argc, argv); if (!opt_servers) - return 0; + { + char *temp; + + if ((temp= getenv("MEMCACHED_SERVERS"))) + opt_servers= strdup(temp); + else + exit(1); + } + + memc= memcached_create(NULL); - memc= memcached_init(NULL); + servers= memcached_servers_parse(opt_servers); - servers= parse_opt_servers(opt_servers); memcached_server_push(memc, servers); memcached_server_list_free(servers); @@ -55,15 +67,18 @@ int main(int argc, char *argv[]) free(string); } } - else + else if (rc != MEMCACHED_NOTFOUND) { - fprintf(stderr, "memcat: %s: memcache error %s\n", + fprintf(stderr, "memcat: %s: memcache error %s", argv[optind], memcached_strerror(memc, rc)); + if (memc->cached_errno) + fprintf(stderr, " system error %s", strerror(memc->cached_errno)); + fprintf(stderr, "\n"); } optind++; } - memcached_deinit(memc); + memcached_free(memc); free(opt_servers); @@ -76,6 +91,11 @@ void options_parse(int argc, char *argv[]) int option_index= 0; int option_rv; + memcached_programs_help_st help_options[]= + { + {0}, + }; + static struct option long_options[]= { {"version", no_argument, NULL, OPT_VERSION}, @@ -102,12 +122,10 @@ void options_parse(int argc, char *argv[]) opt_verbose = OPT_DEBUG; break; case OPT_VERSION: /* --version or -V */ - printf("memcache tools, memcat, v1.0\n"); - exit(0); + version_command(PROGRAM_NAME); break; case OPT_HELP: /* --help or -h */ - printf("useful help messages go here\n"); - exit(0); + help_command(PROGRAM_NAME, PROGRAM_DESCRIPTION, long_options, help_options); break; case OPT_SERVERS: /* --servers or -s */ opt_servers= strdup(optarg);