projects
/
awesomized
/
libmemcached
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
|
github
raw
|
inline
| side by side
Updated tests (including one possible failing test from Brian Moon)
[awesomized/libmemcached]
/
src
/
memcp.c
diff --git
a/src/memcp.c
b/src/memcp.c
index 3cc0109ab4974e827b50381c7233441ea80bf993..09d7e9119b0ec75b30085efe6f11c8eff248ecf8 100644
(file)
--- a/
src/memcp.c
+++ b/
src/memcp.c
@@
-1,4
+1,6
@@
#include <stdio.h>
#include <stdio.h>
+#include <stdlib.h>
+#include <stdint.h>
#include <unistd.h>
#include <getopt.h>
#include <sys/types.h>
#include <unistd.h>
#include <getopt.h>
#include <sys/types.h>
@@
-7,11
+9,16
@@
#include <fcntl.h>
#include <errno.h>
#include <strings.h>
#include <fcntl.h>
#include <errno.h>
#include <strings.h>
+#include <string.h>
+#include <assert.h>
#include <memcached.h>
#include "client_options.h"
#include "utilities.h"
#include <memcached.h>
#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[]);
/* Prototypes */
void options_parse(int argc, char *argv[]);
@@
-25,15
+32,29
@@
int main(int argc, char *argv[])
{
memcached_st *memc;
memcached_return rc;
{
memcached_st *memc;
memcached_return rc;
+ memcached_server_st *servers;
options_parse(argc, argv);
options_parse(argc, argv);
- memc= memcached_init(NULL);
+ memc= memcached_create(NULL);
+
+ if (!opt_servers)
+ {
+ char *temp;
+
+ if ((temp= getenv("MEMCACHED_SERVERS")))
+ opt_servers= strdup(temp);
+ else
+ exit(1);
+ }
if (opt_servers)
if (opt_servers)
-
parse_opt_servers(memc,
opt_servers);
+
servers= memcached_servers_parse(
opt_servers);
else
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)
{
while (optind < argc)
{
@@
-95,15
+116,20
@@
int main(int argc, char *argv[])
opt_expires, opt_flags);
if (rc != MEMCACHED_SUCCESS)
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));
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++;
}
free(file_buffer_ptr);
close(fd);
optind++;
}
- memcached_
deinit
(memc);
+ memcached_
free
(memc);
free(opt_servers);
free(opt_servers);
@@
-115,6
+141,11
@@
void options_parse(int argc, char *argv[])
int option_index= 0;
int option_rv;
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},
static struct option long_options[]=
{
{"version", no_argument, NULL, OPT_VERSION},
@@
-147,11
+178,11
@@
void options_parse(int argc, char *argv[])
opt_verbose = OPT_DEBUG;
break;
case OPT_VERSION: /* --version or -V */
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 */
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_SERVERS: /* --servers or -s */
opt_servers= strdup(optarg);
break;