/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* qmi-firmware-update -- Command line tool to update firmware in QMI devices
*
* 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.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*
* Copyright (C) 2016-2017 Zodiac Inflight Innovations
* Copyright (C) 2016-2017 Aleksander Morgado
*/
#include
#include
#include
#include
#include
#if defined MBIM_QMUX_ENABLED
#include
#endif
#include "qfu-log.h"
static gboolean stdout_silent_flag;
static gboolean stdout_verbose_flag;
static FILE *verbose_log_file;
static void
log_handler (const gchar *log_domain,
GLogLevelFlags log_level,
const gchar *message,
gpointer user_data)
{
const gchar *log_level_str;
time_t now;
gchar time_str[64];
struct tm *local_time;
gboolean err;
/* Nothing to do if we're silent */
if (stdout_silent_flag && !verbose_log_file)
return;
now = time ((time_t *) NULL);
local_time = localtime (&now);
strftime (time_str, 64, "%d %b %Y, %H:%M:%S", local_time);
err = FALSE;
switch (log_level) {
case G_LOG_LEVEL_WARNING:
log_level_str = "-Warning **";
break;
case G_LOG_LEVEL_CRITICAL:
case G_LOG_FLAG_FATAL:
case G_LOG_LEVEL_ERROR:
log_level_str = "-Error **";
err = TRUE;
break;
case G_LOG_LEVEL_DEBUG:
log_level_str = "[Debug]";
break;
default:
log_level_str = "";
break;
}
if (verbose_log_file) {
g_fprintf (verbose_log_file,
"[%s] %s %s\n",
time_str,
log_level_str,
message);
fflush (verbose_log_file);
}
if (stdout_verbose_flag || err)
g_fprintf (err ? stderr : stdout,
"[%s] %s %s\n",
time_str,
log_level_str,
message);
}
gboolean
qfu_log_get_verbose (void)
{
return (stdout_verbose_flag || verbose_log_file);
}
gboolean
qfu_log_get_verbose_stdout (void)
{
return (stdout_verbose_flag);
}
gboolean
qfu_log_init (gboolean stdout_verbose,
gboolean stdout_silent,
const gchar *verbose_log_path)
{
if (stdout_verbose && stdout_silent) {
g_printerr ("error: cannot specify --verbose and --silent at the same time\n");
return FALSE;
}
/* Store flags */
stdout_verbose_flag = stdout_verbose;
stdout_silent_flag = stdout_silent;
/* Open verbose log if required */
if (verbose_log_path) {
verbose_log_file = fopen (verbose_log_path, "w");
if (!verbose_log_file) {
g_printerr ("error: cannot open verbose log file for writing: %s\n", g_strerror (errno));
return FALSE;
}
}
/* Default application logging */
g_log_set_handler (NULL, G_LOG_LEVEL_MASK, log_handler, NULL);
/* libqmi logging */
g_log_set_handler ("Qmi", G_LOG_LEVEL_MASK, log_handler, NULL);
if (stdout_verbose_flag || verbose_log_file)
qmi_utils_set_traces_enabled (TRUE);
#if defined MBIM_QMUX_ENABLED
/* libmbim logging */
g_log_set_handler ("Mbim", G_LOG_LEVEL_MASK, log_handler, NULL);
if (stdout_verbose_flag || verbose_log_file)
mbim_utils_set_traces_enabled (TRUE);
#endif
return TRUE;
}
void
qfu_log_shutdown (void)
{
if (verbose_log_file)
fclose (verbose_log_file);
}