blob: 9ddb60610b13c35c2f664710930f6f3ea7768982 [file] [log] [blame]
snelson5a364a82010-01-07 20:21:58 +00001/*
2 * This file is part of the flashrom project.
3 *
4 * Copyright (C) 2009 Sean Nelson <audiohacked@gmail.com>
Souvik Ghosh3c963a42016-07-19 18:48:15 -07005 * Copyright (C) 2011 Carl-Daniel Hailfinger
snelson5a364a82010-01-07 20:21:58 +00006 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20 */
21
22#include <stdio.h>
23#include <stdarg.h>
Souvik Ghosh3c963a42016-07-19 18:48:15 -070024#include <string.h>
25#include <errno.h>
snelson5a364a82010-01-07 20:21:58 +000026#include "flash.h"
27
Souvik Ghosh3c963a42016-07-19 18:48:15 -070028#ifndef STANDALONE
29static FILE *logfile = NULL;
30
31int close_logfile(void)
32{
33 if (!logfile)
34 return 0;
35 /* No need to call fflush() explicitly, fclose() already does that. */
36 if (fclose(logfile)) {
37 /* fclose returned an error. Stop writing to be safe. */
38 logfile = NULL;
Patrick Georgidbde2f12017-02-03 18:07:45 +010039 msg_gerr("Closing the log file returned error %s\n", strerror(errno));
Souvik Ghosh3c963a42016-07-19 18:48:15 -070040 return 1;
41 }
42 logfile = NULL;
43 return 0;
44}
45
46int open_logfile(const char * const filename)
47{
48 if (!filename) {
Patrick Georgidbde2f12017-02-03 18:07:45 +010049 msg_gerr("No logfile name specified.\n");
Souvik Ghosh3c963a42016-07-19 18:48:15 -070050 return 1;
51 }
52 if ((logfile = fopen(filename, "w")) == NULL) {
53 perror(filename);
54 return 1;
55 }
56 return 0;
57}
58
59void start_logging(void)
60{
61 int oldverbose_screen = verbose_screen;
62
Patrick Georgidbde2f12017-02-03 18:07:45 +010063 /* Shut up the console. */
Souvik Ghosh3c963a42016-07-19 18:48:15 -070064 verbose_screen = MSG_ERROR;
65 print_version();
66 verbose_screen = oldverbose_screen;
67}
68#endif /* !STANDALONE */
69
Patrick Georgidbde2f12017-02-03 18:07:45 +010070/* Please note that level is the verbosity, not the importance of the message. */
71int print(enum msglevel level, const char *fmt, ...)
snelson5a364a82010-01-07 20:21:58 +000072{
73 va_list ap;
74 int ret;
75 FILE *output_type;
uwef6f94d42010-03-13 17:28:29 +000076
Patrick Georgidbde2f12017-02-03 18:07:45 +010077 switch (level) {
snelson5a364a82010-01-07 20:21:58 +000078 case MSG_ERROR:
79 output_type = stderr;
80 break;
Patrick Georgidbde2f12017-02-03 18:07:45 +010081 case MSG_SPEW:
Souvik Ghosh3c963a42016-07-19 18:48:15 -070082 if (verbose_screen < 3)
stefanctee850532011-08-04 17:40:25 +000083 return 0;
84 case MSG_DEBUG2:
Souvik Ghosh3c963a42016-07-19 18:48:15 -070085 if (verbose_screen < 2)
uwef6f94d42010-03-13 17:28:29 +000086 return 0;
snelson5a364a82010-01-07 20:21:58 +000087 case MSG_DEBUG:
Souvik Ghosh3c963a42016-07-19 18:48:15 -070088 if (verbose_screen < 1)
uwef6f94d42010-03-13 17:28:29 +000089 return 0;
snelson5a364a82010-01-07 20:21:58 +000090 case MSG_INFO:
91 default:
92 output_type = stdout;
93 break;
94 }
uwef6f94d42010-03-13 17:28:29 +000095
snelson5a364a82010-01-07 20:21:58 +000096 va_start(ap, fmt);
97 ret = vfprintf(output_type, fmt, ap);
98 va_end(ap);
uwe7ce825d2011-06-19 17:27:57 +000099 fflush(output_type);
Souvik Ghosh3c963a42016-07-19 18:48:15 -0700100
101#ifndef STANDALONE
Patrick Georgidbde2f12017-02-03 18:07:45 +0100102 if ((level <= verbose_logfile) && logfile) {
Souvik Ghosh3c963a42016-07-19 18:48:15 -0700103 va_start(ap, fmt);
104 ret = vfprintf(logfile, fmt, ap);
105 va_end(ap);
Patrick Georgidbde2f12017-02-03 18:07:45 +0100106 if (level != MSG_SPEW)
Souvik Ghosh3c963a42016-07-19 18:48:15 -0700107 fflush(logfile);
108 }
109#endif /* !STANDALONE */
snelson5a364a82010-01-07 20:21:58 +0000110 return ret;
111}