diff options
Diffstat (limited to 'src/Log.cpp')
-rw-r--r-- | src/Log.cpp | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/src/Log.cpp b/src/Log.cpp new file mode 100644 index 00000000..402e4609 --- /dev/null +++ b/src/Log.cpp @@ -0,0 +1,68 @@ +/* + This file is part of Ingen. + Copyright 2007-2012 David Robillard <http://drobilla.net/> + + Ingen is free software: you can redistribute it and/or modify it under the + terms of the GNU Affero General Public License as published by the Free + Software Foundation, either version 3 of the License, or any later version. + + Ingen 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 Affero General Public License for details. + + You should have received a copy of the GNU Affero General Public License + along with Ingen. If not, see <http://www.gnu.org/licenses/>. +*/ + +#include <iostream> + +#include "ingen/Log.hpp" +#include "ingen/URIs.hpp" + +namespace Ingen { + +static const char* const ANSI_RESET = "\033[0m"; +static const char* const ANSI_RED = "\033[0;31m"; +static const char* const ANSI_GREEN = "\033[0;32m"; +static const char* const ANSI_YELLOW = "\033[0;33m"; +static const char* const ANSI_BLUE = "\033[0;34m"; +static const char* const ANSI_MAGENTA = "\033[0;35m"; +static const char* const ANSI_CYAN = "\033[0;36m"; +static const char* const ANSI_WHITE = "\033[0;37m"; + +Log::Log(LV2_Log_Log* log, URIs& uris) + : _log(log) + , _uris(uris) +{} + +void +Log::error(const std::string& msg) +{ + if (_log) { + _log->printf(_log->handle, _uris.log_Error, msg.c_str()); + } else { + std::cerr << ANSI_RED << msg << ANSI_RESET; + } +} + +void +Log::warn(const std::string& msg) +{ + if (_log) { + _log->printf(_log->handle, _uris.log_Warning, msg.c_str()); + } else { + std::cerr << ANSI_YELLOW << msg << ANSI_RESET; + } +} + +void +Log::info(const std::string& msg) +{ + if (_log) { + _log->printf(_log->handle, _uris.log_Note, msg.c_str()); + } else { + std::cout << msg; + } +} + +} // namespace Ingen |