/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details: * * Copyright (C) 2012 Aleksander Morgado */ #include #include "mm-context.h" /* Application context */ static gboolean debug; static const gchar *log_level; static const gchar *log_file; static gboolean show_ts; static gboolean rel_ts; static const GOptionEntry entries[] = { { "debug", 0, 0, G_OPTION_ARG_NONE, &debug, "Run with extended debugging capabilities", NULL }, { "log-level", 0, 0, G_OPTION_ARG_STRING, &log_level, "Log level: one of [ERR, WARN, INFO, DEBUG]", "INFO" }, { "log-file", 0, 0, G_OPTION_ARG_STRING, &log_file, "Path to log file", NULL }, { "timestamps", 0, 0, G_OPTION_ARG_NONE, &show_ts, "Show timestamps in log output", NULL }, { "relative-timestamps", 0, 0, G_OPTION_ARG_NONE, &rel_ts, "Use relative timestamps (from MM start)", NULL }, { NULL } }; gboolean mm_context_get_debug (void) { return debug; } const gchar * mm_context_get_log_level (void) { return log_level; } const gchar * mm_context_get_log_file (void) { return log_file; } gboolean mm_context_get_timestamps (void) { return show_ts; } gboolean mm_context_get_relative_timestamps (void) { return rel_ts; } void mm_context_init (gint argc, gchar **argv) { GError *error = NULL; GOptionContext *ctx; ctx = g_option_context_new (NULL); g_option_context_set_summary (ctx, "DBus system service to communicate with modems."); g_option_context_add_main_entries (ctx, entries, NULL); if (!g_option_context_parse (ctx, &argc, &argv, &error)) { g_warning ("%s\n", error->message); g_error_free (error); exit (1); } g_option_context_free (ctx); /* Additional setup to be done on debug mode */ if (debug) { log_level = "DEBUG"; if (!show_ts && !rel_ts) show_ts = TRUE; } }