1// SuperTux Debug Helper Functions
2// Copyright (C) 2006 Christoph Sommer <christoph.sommer@2006.expires.deltadevelopment.de>
3// Copyright (C) 2010 Florian Forster <supertux at octo.it>
4//
5// This program is free software: you can redistribute it and/or modify
6// it under the terms of the GNU General Public License as published by
7// the Free Software Foundation, either version 3 of the License, or
8// (at your option) any later version.
9//
10// This program is distributed in the hope that it will be useful,
11// but WITHOUT ANY WARRANTY; without even the implied warranty of
12// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13// GNU General Public License for more details.
14//
15// You should have received a copy of the GNU General Public License
16// along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18#include "util/log.hpp"
19
20#include <iostream>
21
22#include "math/rectf.hpp"
23#include "supertux/console.hpp"
24#include "supertux/gameconfig.hpp"
25#include "supertux/globals.hpp"
26
27LogLevel g_log_level = LOG_WARNING;
28
29static std::ostream& get_logging_instance (bool use_console_buffer = true)
30{
31 if (ConsoleBuffer::current() && use_console_buffer)
32 return (ConsoleBuffer::output);
33 else
34 return (std::cerr);
35}
36
37static std::ostream& log_generic_f (const char *prefix, const char* file, int line, bool use_console_buffer = true)
38{
39 get_logging_instance (use_console_buffer) << prefix << " " << file << ":" << line << " ";
40 return (get_logging_instance (use_console_buffer));
41}
42
43std::ostream& log_debug_f(const char* file, int line, bool use_console_buffer = true)
44{
45 return (log_generic_f ("[DEBUG]", file, line, use_console_buffer));
46}
47
48std::ostream& log_info_f(const char* file, int line)
49{
50 return (log_generic_f ("[INFO]", file, line));
51}
52
53std::ostream& log_warning_f(const char* file, int line)
54{
55 if (g_config && g_config->developer_mode &&
56 Console::current() && !Console::current()->hasFocus()) {
57 Console::current()->open();
58 }
59 return (log_generic_f ("[WARNING]", file, line));
60}
61
62std::ostream& log_fatal_f(const char* file, int line)
63{
64 if (g_config && g_config->developer_mode &&
65 Console::current() && !Console::current()->hasFocus()) {
66 Console::current()->open();
67 }
68 return (log_generic_f ("[FATAL]", file, line));
69}
70
71/* Callbacks used by tinygettext */
72void log_info_callback(const std::string& str)
73{
74 log_info << "\r\n[TINYGETTEXT] " << str << std::endl;
75}
76
77void log_warning_callback(const std::string& str)
78{
79 log_debug << "\r\n[TINYGETTEXT] " << str << std::endl;
80}
81
82void log_error_callback(const std::string& str)
83{
84 log_warning << "\r\n[TINYGETTEXT] " << str << std::endl;
85}
86
87/* EOF */
88