/* vim: set sw=4 sts=4 et foldmethod=syntax : */ /* * Copyright (c) 2010, 2011 Ciaran McCreesh * * This file is part of the Paludis package manager. Paludis is free software; * you can redistribute it and/or modify it under the terms of the GNU General * Public License version 2, as published by the Free Software Foundation. * * Paludis 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 * this program; if not, write to the Free Software Foundation, Inc., 59 Temple * Place, Suite 330, Boston, MA 02111-1307 USA */ #include #include #include #include #include #include #include #include using namespace paludis; namespace paludis { template <> struct Imp { DiscardOutputStream stream; const std::shared_ptr child; const std::string format_debug; const std::string format_info; const std::string format_warn; const std::string format_error; const std::string format_log; const std::string format_status; const FormatMessagesOutputManagerFormatFunction format_func; Imp( const std::shared_ptr & c, const std::string & d, const std::string & i, const std::string & w, const std::string & e, const std::string & l, const std::string & s, const FormatMessagesOutputManagerFormatFunction & f ) : child(c), format_debug(d), format_info(i), format_warn(w), format_error(e), format_log(l), format_status(s), format_func(f) { } }; } FormatMessagesOutputManager::FormatMessagesOutputManager( const std::shared_ptr & child, const std::string & format_debug, const std::string & format_info, const std::string & format_warn, const std::string & format_error, const std::string & format_log, const FormatMessagesOutputManagerFormatFunction & f) : _imp(child, format_debug, format_info, format_warn, format_error, format_log, "", f) { } FormatMessagesOutputManager::FormatMessagesOutputManager( const std::shared_ptr & child, const std::string & format_debug, const std::string & format_info, const std::string & format_warn, const std::string & format_error, const std::string & format_log, const std::string & format_status, const FormatMessagesOutputManagerFormatFunction & f) : _imp(child, format_debug, format_info, format_warn, format_error, format_log, format_status, f) { } FormatMessagesOutputManager::~FormatMessagesOutputManager() { } std::ostream & FormatMessagesOutputManager::stdout_stream() { return _imp->stream; } std::ostream & FormatMessagesOutputManager::stderr_stream() { return _imp->stream; } void FormatMessagesOutputManager::message(const MessageType t, const std::string & s) { std::string f; switch (t) { case mt_info: f = _imp->format_info; break; case mt_debug: f = _imp->format_debug; break; case mt_warn: f = _imp->format_warn; break; case mt_error: f = _imp->format_error; break; case mt_log: f = _imp->format_log; break; case mt_status: f = _imp->format_status; break; case last_mt: break; } if (f.empty()) return; f = _imp->format_func(f, s); _imp->child->stdout_stream() << f << std::flush; } void FormatMessagesOutputManager::succeeded() { _imp->child->succeeded(); } void FormatMessagesOutputManager::ignore_succeeded() { _imp->child->ignore_succeeded(); } void FormatMessagesOutputManager::flush() { _imp->child->flush(); } bool FormatMessagesOutputManager::want_to_flush() const { return _imp->child->want_to_flush(); } void FormatMessagesOutputManager::nothing_more_to_come() { _imp->child->nothing_more_to_come(); } const std::shared_ptr > FormatMessagesOutputManager::factory_managers() { std::shared_ptr > result(std::make_shared>()); result->insert("format_messages"); return result; } namespace { struct FormatMessage { const OutputManagerFactory::ReplaceVarsFunc r; std::string operator() (const std::string & f, const std::string & s) { std::shared_ptr > m(std::make_shared>()); m->insert("message", s); return r(f, m); } }; } const std::shared_ptr FormatMessagesOutputManager::factory_create( const OutputManagerFactory::KeyFunction & key_func, const OutputManagerFactory::CreateChildFunction & create_child_function, const OutputManagerFactory::ReplaceVarsFunc & replace_vars_func) { std::string child_s(key_func("child")), format_debug_s(key_func("format_debug")), format_info_s(key_func("format_info")), format_warn_s(key_func("format_warn")), format_error_s(key_func("format_error")), format_log_s(key_func("format_log")), format_status_s(key_func("format_status")); std::shared_ptr child(create_child_function(child_s)); return std::make_shared( child, format_debug_s, format_info_s, format_warn_s, format_error_s, format_log_s, format_status_s, FormatMessage{replace_vars_func}); } namespace paludis { template class Pimp; }