X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fmemcp.c;h=57d0a70da61282d5207b12c0e34d7f17db35c2b6;hb=2c213592852ceb196be1b1760d17284150fc0678;hp=0eb210a701c13dd45ec10c29ceeeba8bd31a877e;hpb=ad33b231aaf0e26cc56050c50d0b023b70da335d;p=awesomized%2Flibmemcached diff --git a/src/memcp.c b/src/memcp.c index 0eb210a7..57d0a70d 100644 --- a/src/memcp.c +++ b/src/memcp.c @@ -24,8 +24,9 @@ void options_parse(int argc, char *argv[]); static int opt_verbose= 0; static char *opt_servers= NULL; +static char *opt_hash= NULL; static int opt_method= OPT_SET; -static uint16_t opt_flags= 0; +static uint32_t opt_flags= 0; static time_t opt_expires= 0; int main(int argc, char *argv[]) @@ -37,6 +38,7 @@ int main(int argc, char *argv[]) options_parse(argc, argv); memc= memcached_create(NULL); + process_hash_option(memc, opt_hash); if (!opt_servers) { @@ -119,8 +121,8 @@ int main(int argc, char *argv[]) { fprintf(stderr, "memcp: %s: memcache error %s", ptr, memcached_strerror(memc, rc)); - if (memc->my_errno) - fprintf(stderr, " system error %s", strerror(memc->my_errno)); + if (memc->cached_errno) + fprintf(stderr, " system error %s", strerror(memc->cached_errno)); fprintf(stderr, "\n"); } @@ -131,7 +133,10 @@ int main(int argc, char *argv[]) memcached_free(memc); - free(opt_servers); + if (opt_servers) + free(opt_servers); + if (opt_hash) + free(opt_hash); return 0; } @@ -158,6 +163,7 @@ void options_parse(int argc, char *argv[]) {"set", no_argument, NULL, OPT_SET}, {"add", no_argument, NULL, OPT_ADD}, {"replace", no_argument, NULL, OPT_REPLACE}, + {"hash", required_argument, NULL, OPT_HASH}, {0, 0, 0, 0}, }; @@ -187,7 +193,7 @@ void options_parse(int argc, char *argv[]) opt_servers= strdup(optarg); break; case OPT_FLAG: /* --flag */ - opt_flags= (uint16_t)strtol(optarg, (char **)NULL, 16); + opt_flags= (uint32_t)strtol(optarg, (char **)NULL, 16); break; case OPT_EXPIRE: /* --expire */ opt_expires= (time_t)strtoll(optarg, (char **)NULL, 10); @@ -200,6 +206,8 @@ void options_parse(int argc, char *argv[]) break; case OPT_ADD: opt_method= OPT_ADD; + case OPT_HASH: + opt_hash= strdup(optarg); break; case '?': /* getopt_long already printed an error message. */