summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: f9ee71b)
raw | patch | inline | side by side (parent: f9ee71b)
author | octo <octo> | |
Fri, 16 Dec 2005 09:58:46 +0000 (09:58 +0000) | ||
committer | octo <octo> | |
Fri, 16 Dec 2005 09:58:46 +0000 (09:58 +0000) |
- Changed command line options to be more consitent
- Hopefully changed automake to it creates directories
- Hopefully changed automake to it creates directories
src/Makefile.am | patch | blob | history | |
src/collectd.c | patch | blob | history | |
src/collectd.h | patch | blob | history |
diff --git a/src/Makefile.am b/src/Makefile.am
index 4f271bf2664a9ebe5d37a0522f7509986f737c9b..ae7df9ba5e95f13503366dd85bfc3022b34d16e9 100644 (file)
--- a/src/Makefile.am
+++ b/src/Makefile.am
multicast.c multicast.h \
plugin.c plugin.h
#collectd_CFLAGS = -DPLUGINDIR='"$(pkglibdir)"'
-collectd_CPPFLAGS = -DLOCALSTATEDIR='"$(localstatedir)"' -DPLUGINDIR='"$(pkglibdir)"'
+collectd_CPPFLAGS =
+collectd_CPPFLAGS += -DSYSCONFDIR='"${sysconfdir}"'
+collectd_CPPFLAGS += -DPKGLOCALSTATEDIR='"${localstatedir}/${PACKAGE_NAME}"'
+collectd_CPPFLAGS += -DPIDFILE='"${localstatedir}/run/${PACKAGE_NAME}.pid"'
+collectd_CPPFLAGS += -DPLUGINDIR='"${pkglibdir}"'
collectd_LDFLAGS = -export-dynamic
collectd_CFLAGS = -Werror
collectd_LDADD = $(LIBLTDL) "-dlopen" self
pkglib_LTLIBRARIES += users.la
users_la_SOURCES = users.c users.h
users_la_LDFLAGS = -module -avoid-version
+users_la_CFLAGS = -Werror
collectd_LDADD += "-dlopen" users.la
collectd_DEPENDENCIES += users.la
endif
diff --git a/src/collectd.c b/src/collectd.c
index 633d0230cdec080c7f5a924eba6e4e6fb44e112e..9932fd90a4830ed21f00104f3d940558c92a8913 100644 (file)
--- a/src/collectd.c
+++ b/src/collectd.c
"Available options:\n"
" General:\n"
- " -d <dir> Base directory to use.\n"
+ " -C <dir> Configuration directory.\n"
" Default: %s\n"
- " -P <dir> Set the plugin-directory\n"
+ " -P <file> PID File.\n"
" Default: %s\n"
- " -f Don't fork to the background\n"
+ " -M <dir> Module/Plugin directory.\n"
+ " Default: %s\n"
+ " -D <dir> Data storage directory.\n"
+ " Default: %s\n"
+ " -f Don't fork to the background.\n"
#ifdef HAVE_LIBRRD
- " -l Start in local mode (no network)\n"
- " -c Start in client (sender) mode\n"
- " -s Start in server (listener) mode\n"
+ " -l Start in local mode (no network).\n"
+ " -c Start in client (sender) mode.\n"
+ " -s Start in server (listener) mode.\n"
#endif /* HAVE_LIBRRD */
#if COLLECT_PING
" Ping:\n"
"\n%s %s, http://verplant.org/collectd/\n"
"by Florian octo Forster <octo@verplant.org>\n"
"for contributions see `AUTHORS'\n",
- PACKAGE, DATADIR, PLUGINDIR, PACKAGE, VERSION);
+ PACKAGE, SYSCONFDIR, PIDFILE, PLUGINDIR, PKGLOCALSTATEDIR, PACKAGE, VERSION);
exit (0);
}
pid_t pid;
#endif
- char *plugindir = NULL;
- char *basedir = DATADIR;
+ char *confdir = SYSCONFDIR;
+ char *pidfile = PIDFILE;
+ char *plugindir = PLUGINDIR;
+ char *datadir = PKGLOCALSTATEDIR;
int daemonize = 1;
operating_mode = MODE_LOCAL;
#endif
- /*
- * open syslog
- */
+ /* open syslog */
openlog (PACKAGE, LOG_CONS | LOG_PID, LOG_DAEMON);
- /*
- * read options
- */
+ /* read options */
while (1)
{
int c;
- c = getopt (argc, argv, "d:fP:h"
+ c = getopt (argc, argv, "C:P:M:D:fh"
#if HAVE_LIBRRD
"csl"
#endif /* HAVE_LIBRRD */
operating_mode = MODE_LOCAL;
break;
#endif /* HAVE_LIBRRD */
- case 'd':
- basedir = optarg;
+ case 'C':
+ confdir = optarg;
+ break;
+ case 'P':
+ pidfile = optarg;
+ break;
+ case 'M':
+ plugindir = optarg;
+ break;
+ case 'D':
+ datadir = optarg;
break;
case 'f':
daemonize = 0;
fprintf (stderr, "Maximum of %i ping hosts reached.\n", MAX_PINGHOSTS);
break;
#endif /* COLLECT_PING */
- case 'P':
- plugindir = optarg;
- break;
-
case 'h':
default:
exit_usage (argv[0]);
return (1);
}
- if (change_basedir (basedir))
+ if (change_basedir (datadir))
{
- fprintf (stderr, "Error: Unable to change to directory `%s'.\n", basedir);
+ fprintf (stderr, "Error: Unable to change to directory `%s'.\n", datadir);
return (1);
}
#endif
start_client ();
- /*
- * close syslog
- */
+ /* close syslog */
syslog (LOG_INFO, "Exiting normally");
closelog ();
diff --git a/src/collectd.h b/src/collectd.h
index c7aa925ae4d23547d3807c0f1c5f28a7a1554463..64fe463c260b3addfb14c8c8d5efa824da192868 100644 (file)
--- a/src/collectd.h
+++ b/src/collectd.h
# include <ctype.h>
#endif
+#if HAVE_SYSLOG
+# define syslog(...) syslog(__VA_ARGS__)
+# if HAVE_OPENLOG
+# define openlog(...) openlog(__VA_ARGS__)
+# else
+# define openlog(...) /**/
+# endif
+# if HAVE_CLOSELOG
+# define closelog(...) closelog(__VA_ARGS__)
+# else
+# define closelog(...) /**/
+# endif
+#else
+# define syslog(...) /**/
+# define openlog(...) /**/
+# define closelog(...) /**/
+#endif
+
#ifndef HAVE_RRD_H
#undef HAVE_LIBRRD
#endif
#include <statgrab.h>
#endif
-#ifndef LOCALSTATEDIR
-#define LOCALSTATEDIR "/opt/collectd/var"
-#endif
-
-#ifndef DATADIR
-#define DATADIR LOCALSTATEDIR"/lib/collectd"
-#endif
-
-#ifndef PLUGINDIR
-#define PLUGINDIR "/opt/collectd/lib/collectd"
-#endif
-
-#ifndef PIDFILE
-#define PIDFILE LOCALSTATEDIR"/run/collectd.pid"
-#endif
-
#define MODE_SERVER 0x01
#define MODE_CLIENT 0x02
#define MODE_LOCAL 0x03