diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2009-12-23 03:39:00 -0800 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2009-12-23 03:39:00 -0800 |
commit | b766c33ef02179be43134aaf533a844b93269a64 (patch) | |
tree | 0dd70ac87058ade7147ade42e525faa62fd0bca6 /tools/supplicant-test.c | |
parent | 50b6b290937326d078190540fc451001666afd8e (diff) | |
download | connman-b766c33ef02179be43134aaf533a844b93269a64.tar.gz connman-b766c33ef02179be43134aaf533a844b93269a64.tar.bz2 connman-b766c33ef02179be43134aaf533a844b93269a64.zip |
Add basic mainloop and D-Bus setup to supplicant test tool
Diffstat (limited to 'tools/supplicant-test.c')
-rw-r--r-- | tools/supplicant-test.c | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/tools/supplicant-test.c b/tools/supplicant-test.c index 6f110c17..24fd5d8f 100644 --- a/tools/supplicant-test.c +++ b/tools/supplicant-test.c @@ -23,7 +23,74 @@ #include <config.h> #endif +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <signal.h> +#include <syslog.h> + +#include <gdbus.h> + +#define DBG(fmt, arg...) do { \ + syslog(LOG_DEBUG, "%s:%s() " fmt, __FILE__, __FUNCTION__ , ## arg); \ +} while (0) + +static GMainLoop *main_loop = NULL; + +static void sig_term(int sig) +{ + syslog(LOG_INFO, "Terminating"); + + g_main_loop_quit(main_loop); +} + +static void disconnect_callback(DBusConnection *conn, void *user_data) +{ + syslog(LOG_ERR, "D-Bus disconnect"); + + g_main_loop_quit(main_loop); +} + int main(int argc, char *argv[]) { + DBusConnection *conn; + DBusError err; + struct sigaction sa; + + main_loop = g_main_loop_new(NULL, FALSE); + + dbus_error_init(&err); + + conn = g_dbus_setup_bus(DBUS_BUS_SYSTEM, NULL, &err); + if (conn == NULL) { + if (dbus_error_is_set(&err) == TRUE) { + fprintf(stderr, "%s\n", err.message); + dbus_error_free(&err); + } else + fprintf(stderr, "Can't register with system bus\n"); + exit(1); + } + + openlog("supplicant", LOG_NDELAY | LOG_PERROR, LOG_USER); + + g_dbus_set_disconnect_function(conn, disconnect_callback, NULL, NULL); + + memset(&sa, 0, sizeof(sa)); + sa.sa_handler = sig_term; + sigaction(SIGINT, &sa, NULL); + sigaction(SIGTERM, &sa, NULL); + + syslog(LOG_INFO, "Startup"); + + g_main_loop_run(main_loop); + + syslog(LOG_INFO, "Exit"); + + dbus_connection_unref(conn); + + g_main_loop_unref(main_loop); + + closelog(); + return 0; } |