// SuperTux Debug Helper Functions
// Copyright (C) 2006 Christoph Sommer <christoph.sommer@2006.expires.deltadevelopment.de>
+// Copyright (C) 2010 Florian Forster <supertux at octo.it>
//
// 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
#include "util/log.hpp"
+#include <iostream>
+
#include "math/rectf.hpp"
#include "supertux/console.hpp"
-#ifndef NDEBUG
+LogLevel g_log_level = LOG_WARNING;
+
+static std::ostream& get_logging_instance (void)
+{
+ if (ConsoleBuffer::current())
+ return (ConsoleBuffer::output);
+ else
+ return (std::cerr);
+}
-std::ostream& log_debug_f(const char* file, int line)
+static std::ostream& log_generic_f (const char *prefix, const char* file, int line)
{
- Console::output << "[DEBUG] " << file << ":" << line << " ";
- return Console::output;
+ get_logging_instance () << prefix << " " << file << ":" << line << " ";
+ return (get_logging_instance ());
}
-std::ostream& log_info_f(const char* file, int line)
+std::ostream& log_debug_f(const char* file, int line)
{
- Console::output << "[INFO] " << file << ":" << line << " ";
- return Console::output;
+ return (log_generic_f ("[DEBUG]", file, line));
}
-std::ostream& log_warning_f(const char* file, int line)
+std::ostream& log_info_f(const char* file, int line)
{
- Console::output << "[WARNING] " << file << ":" << line << " ";
- return Console::output;
+ return (log_generic_f ("[INFO]", file, line));
}
-#endif
+std::ostream& log_warning_f(const char* file, int line)
+{
+ return (log_generic_f ("[WARNING]", file, line));
+}
-std::ostream& log_fatal_f(const char* file, int line)
+std::ostream& log_fatal_f(const char* file, int line)
{
- Console::output << "[FATAL] " << file << ":" << line << " ";
- return Console::output;
+ return (log_generic_f ("[FATAL]", file, line));
}
std::ostream& operator<<(std::ostream& out, const Vector& vector)