summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 55d2fac)
raw | patch | inline | side by side (parent: 55d2fac)
author | Paul Sadauskas <psadauskas@gmail.com> | |
Mon, 6 Jul 2009 19:50:49 +0000 (13:50 -0600) | ||
committer | Florian Forster <octo@leeloo.lan.home.verplant.org> | |
Mon, 6 Jul 2009 20:39:19 +0000 (22:39 +0200) |
src/tokyotyrant.c | patch | blob | history |
diff --git a/src/tokyotyrant.c b/src/tokyotyrant.c
index b59315cbd1493756c743f686c5e5250d1542aff3..977e11b59dd4e16d69d19386651036a1ea69853f 100644 (file)
--- a/src/tokyotyrant.c
+++ b/src/tokyotyrant.c
#include "utils_parse_option.h"
#include <tcrdb.h>
+#define DEFAULT_HOST "127.0.0.1"
+#define DEFAULT_PORT 1978
+
static const char *config_keys[] =
{
"Host",
};
static int config_keys_num = STATIC_ARRAY_SIZE (config_keys);
-static char *host = NULL;
-static int port;
-static char port_str[5];
+static char *config_host = NULL;
+static char *config_port = NULL;
static int tt_config (const char *key, const char *value)
{
if (strcasecmp ("Host", key) == 0)
{
- if (host != NULL)
- free (host);
- host = strdup(value);
+ char *temp;
+
+ temp = strdup (value);
+ if (temp == NULL)
+ {
+ ERROR("tokyotyrant plugin: Host strdup failed.");
+ return (1);
+ }
+ sfree (config_host);
+ config_host = temp;
}
else if (strcasecmp ("Port", key) == 0)
{
- port = atoi(value);
- if ((port < 0) || (port > 65535))
+ char *temp;
+
+ temp = strdup (value);
+ if (temp == NULL)
{
- ERROR ("tokyotyrant plugin: error: Port %s out of range", value);
- return (-1);
+ ERROR("tokyotyrant plugin: Port strdup failed.");
+ return (1);
}
- ssnprintf(port_str, 5, "%i", port);
+ sfree (config_port);
+ config_port = temp;
}
else
{
vl.values = values;
vl.values_len = STATIC_ARRAY_SIZE (values);
- sstrncpy (vl.host, host, sizeof (vl.host));
+ sstrncpy (vl.host, config_host, sizeof (vl.host));
sstrncpy (vl.plugin, "tokyotyrant", sizeof (vl.plugin));
- sstrncpy (vl.plugin_instance, port_str,
+ sstrncpy (vl.plugin_instance, config_port,
sizeof (vl.plugin_instance));
sstrncpy (vl.type, type, sizeof (vl.type));
static int tt_read (void) {
gauge_t rnum, size;
+ char* host = NULL;
+ int port;
+
+ host = ((config_host != NULL) ? config_host : DEFAULT_HOST);
+ port = ((config_port != NULL) ? atoi(config_port) : DEFAULT_PORT);
+
TCRDB *rdb = tcrdbnew();
if (!tcrdbopen(rdb, host, port))
return (1);
}
+ tcrdbdel (rdb);
return (0);
}
+static int tt_shutdown(void)
+{
+ sfree(config_host);
+ sfree(config_port);
+
+ return(0);
+}
+
void module_register (void)
{
plugin_register_config("tokyotyrant", tt_config,
config_keys, config_keys_num);
plugin_register_read("tokyotyrant", tt_read);
+ plugin_register_shutdown("tokyotyrant", tt_shutdown);
}
/* vim: set sw=8 ts=8 tw=78 : */