1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
/*
This file is part of LilyPond, the GNU music typesetter.
Copyright (C) 1997--2011 Han-Wen Nienhuys <hanwen@xs4all.nl>
LilyPond 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 3 of the License, or
(at your option) any later version.
LilyPond 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 LilyPond. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef WARN_HH
#define WARN_HH
#include "std-string.hh"
/* Log-level bitmasks */
#define LOG_NONE 0
#define LOG_ERROR 1<<0
#define LOG_WARN 1<<1
#define LOG_BASIC 1<<2 // undocumented basic_progress, i.e. input file name and success
#define LOG_PROGRESS 1<<3
#define LOG_INFO 1<<4
#define LOG_DEBUG 1<<8
/* Log-level definitions (or'ed bitmasks) */
#define LOGLEVEL_NONE (LOG_NONE)
#define LOGLEVEL_ERROR (LOG_ERROR)
#define LOGLEVEL_WARN (LOGLEVEL_ERROR | LOG_WARN)
#define LOGLEVEL_BASIC (LOGLEVEL_WARN | LOG_BASIC)
#define LOGLEVEL_PROGRESS (LOGLEVEL_BASIC | LOG_PROGRESS)
#define LOGLEVEL_INFO (LOGLEVEL_PROGRESS | LOG_INFO)
#define LOGLEVEL_DEBUG (LOGLEVEL_INFO | LOG_DEBUG)
extern int loglevel;
extern bool warning_as_error;
/* output messages, in decreasing order of importance */
void error (string s, string location = ""); // Fatal error, exits lilypond!
void programming_error (string s, string location = "");
void non_fatal_error (string, string location = "");
void warning (string s, string location = "");
void basic_progress (string s, string location = "");
/* progress_indication does by default *NOT* start on a new line */
void progress_indication (string s, bool newline = false, string location = "");
void message (string s, bool newline = true, string location = "");
void debug_output (string s, bool newline = true, string location = "");
/* Helper functions that always print out the message. Callers should ensure
that the loglevel is obeyed */
void print_message (int level, string location, string s, bool newline = true);
bool is_loglevel (int level);
void set_loglevel (int level);
void set_loglevel (string level);
void expect_warning (string msg);
void check_expected_warnings ();
#endif /* WARN_HH */
|