X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fmemcp.c;h=f1054ea9d1518d2a969afcf5b32cead3099f02a1;hb=7440e41da7475141f68195d678abcabd8fc3db23;hp=3b846e78fa5025616631a921a752623cd73a4817;hpb=7bfd925c54662cf1f67b651559dd91f77bfe8817;p=m6w6%2Flibmemcached diff --git a/src/memcp.c b/src/memcp.c index 3b846e78..f1054ea9 100644 --- a/src/memcp.c +++ b/src/memcp.c @@ -1,4 +1,6 @@ #include +#include +#include #include #include #include @@ -7,6 +9,8 @@ #include #include #include +#include +#include #include #include "client_options.h" @@ -21,7 +25,7 @@ void options_parse(int argc, char *argv[]); static int opt_verbose= 0; static char *opt_servers= 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[]) @@ -32,15 +36,22 @@ int main(int argc, char *argv[]) options_parse(argc, argv); - memc= memcached_init(NULL); + memc= memcached_create(NULL); if (!opt_servers) - return 0; + { + char *temp; + + if ((temp= getenv("MEMCACHED_SERVERS"))) + opt_servers= strdup(temp); + else + exit(1); + } if (opt_servers) - servers= parse_opt_servers(opt_servers); + servers= memcached_servers_parse(opt_servers); else - servers= parse_opt_servers(argv[--argc]); + servers= memcached_servers_parse(argv[--argc]); memcached_server_push(memc, servers); memcached_server_list_free(servers); @@ -105,15 +116,20 @@ int main(int argc, char *argv[]) opt_expires, opt_flags); if (rc != MEMCACHED_SUCCESS) - fprintf(stderr, "memcp: %s: memcache error %s\n", + { + fprintf(stderr, "memcp: %s: memcache error %s", ptr, memcached_strerror(memc, rc)); + if (memc->cached_errno) + fprintf(stderr, " system error %s", strerror(memc->cached_errno)); + fprintf(stderr, "\n"); + } free(file_buffer_ptr); close(fd); optind++; } - memcached_deinit(memc); + memcached_free(memc); free(opt_servers); @@ -171,7 +187,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);