X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fmemcat.c;h=7789ec9b4e0f72f813257c0320c441ba6adee291;hb=8a685f7ae7c61368a40cd702c55bd662c25891b2;hp=eb85329125c3428d59e3b49ed1b2f8a94e2cd092;hpb=8a5eacba0596082949034333adbc4e01f339069b;p=m6w6%2Flibmemcached diff --git a/src/memcat.c b/src/memcat.c index eb853291..7789ec9b 100644 --- a/src/memcat.c +++ b/src/memcat.c @@ -2,25 +2,18 @@ #include #include #include + #include "client_options.h" +#include "utilities.h" + + +/* Prototypes */ +void options_parse(int argc, char *argv[]); static int opt_verbose; static int opt_displayflag; static char *opt_servers; -struct memcached_st *parse_opt_servers (struct memcached_st *m, - char *opt_servers) -{ - char *s, *hostname; - unsigned int portnum; - while (s = strsep(&opt_servers, ",")) { - hostname = strsep(&s, ":"); - portnum = atoi(s); - memcached_server_add(m, hostname, portnum); - } - return m; -} - int main(int argc, char *argv[]) { memcached_st *memc; @@ -29,6 +22,47 @@ int main(int argc, char *argv[]) uint16_t flags; memcached_return rc; + memc= memcached_init(NULL); + + options_parse(argc, argv); + + parse_opt_servers(memc, opt_servers); + + while (optind <= argc) + { + string= memcached_get(memc, argv[argc], strlen(argv[argc]), + &string_length, &flags, &rc); + if (rc == MEMCACHED_SUCCESS) + { + if (opt_displayflag) + { + if (opt_verbose) + printf("key: %.*s\nflags: ", argv[argc]); + printf("%d\n", flags); + } + else + { + if (opt_verbose) + printf("key: %.*s\nflags: %d\nlength: %d\nvalue: ", + argv[argc], flags, string_length); + printf("%.*s\n", string_length, string); + free(string); + } + } + optind++; + } + + memcached_deinit(memc); + + return 0; +}; + + +void options_parse(int argc, char *argv[]) +{ + int option_index = 0; + int option_rv; + static struct option long_options[] = { {"version", no_argument, NULL, OPT_VERSION}, @@ -39,26 +73,24 @@ int main(int argc, char *argv[]) {"flag", no_argument, &opt_displayflag, OPT_FLAG}, {0, 0, 0, 0}, }; - int option_index = 0; - int option_rv; while (1) { - option_rv = getopt_long(argc, argv, "", long_options, &option_index); + option_rv = getopt_long(argc, argv, "Vhvds:", long_options, &option_index); if (option_rv == -1) break; switch (option_rv) { case 0: break; - case OPT_VERSION: /* --version */ + case OPT_VERSION: /* --version or -V */ printf("memcache tools, memcat, v1.0\n"); exit(0); break; - case OPT_HELP: /* --help */ + case OPT_HELP: /* --help or -h */ printf("useful help messages go here\n"); exit(0); break; - case OPT_SERVERS: /* --servers */ - opt_servers = strdup(optarg); + case OPT_SERVERS: /* --servers or -s */ + opt_servers= optarg; break; case '?': /* getopt_long already printed an error message. */ @@ -67,29 +99,4 @@ int main(int argc, char *argv[]) abort(); } } - - memc= memcached_init(NULL); - memc= parse_opt_servers(memc, opt_servers); - - while (optind < argc) { - string= memcached_get(memc, argv[optind], strlen(argv[optind]), - &string_length, &flags, &rc); - if (rc == MEMCACHED_SUCCESS) { - if (opt_displayflag) { - printf("%d\n", flags); - } else { - if (string) - { - printf("%.*s\n", string_length, string); - free(string); - } - } - } - - optind++; - } - - memcached_deinit(memc); - - return 0; -}; +}