X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fmemcp.c;h=57d0a70da61282d5207b12c0e34d7f17db35c2b6;hb=42a7cc99572d9cf161e9db04f31e123b5431df10;hp=3cc0109ab4974e827b50381c7233441ea80bf993;hpb=ccd00450d57624afba24bfbb6e76d1d69d0ad0f8;p=m6w6%2Flibmemcached diff --git a/src/memcp.c b/src/memcp.c index 3cc0109a..57d0a70d 100644 --- a/src/memcp.c +++ b/src/memcp.c @@ -1,4 +1,6 @@ #include +#include +#include #include #include #include @@ -7,33 +9,54 @@ #include #include #include +#include +#include #include #include "client_options.h" #include "utilities.h" +#define PROGRAM_NAME "memcp" +#define PROGRAM_DESCRIPTION "Copy a set of files to a memcached cluster." + /* Prototypes */ 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[]) { memcached_st *memc; memcached_return rc; + memcached_server_st *servers; options_parse(argc, argv); - memc= memcached_init(NULL); + memc= memcached_create(NULL); + process_hash_option(memc, opt_hash); + + if (!opt_servers) + { + char *temp; + + if ((temp= getenv("MEMCACHED_SERVERS"))) + opt_servers= strdup(temp); + else + exit(1); + } if (opt_servers) - parse_opt_servers(memc, opt_servers); + servers= memcached_servers_parse(opt_servers); else - parse_opt_servers(memc, argv[--argc]); + servers= memcached_servers_parse(argv[--argc]); + + memcached_server_push(memc, servers); + memcached_server_list_free(servers); while (optind < argc) { @@ -95,17 +118,25 @@ 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); + if (opt_servers) + free(opt_servers); + if (opt_hash) + free(opt_hash); return 0; } @@ -115,6 +146,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}, @@ -127,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}, }; @@ -147,16 +184,16 @@ void options_parse(int argc, char *argv[]) opt_verbose = OPT_DEBUG; break; case OPT_VERSION: /* --version or -V */ - printf("memcache tools, memcp, 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); 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); @@ -169,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. */