office-gobmx/configmgr/source/inc/logger.hxx
2008-10-29 14:38:47 +00:00

116 lines
5.4 KiB
C++

/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: logger.hxx,v $
* $Revision: 1.4 $
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org 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 Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef CONFIGMGR_LOGGER_HXX
#define CONFIGMGR_LOGGER_HXX
#include <com/sun/star/uno/XComponentContext.hpp>
#include <com/sun/star/util/logging/XLogger.hpp>
#include <com/sun/star/util/logging/LogLevel.hpp>
namespace configmgr
{
// -----------------------------------------------------------------------------
namespace uno = com::sun::star::uno;
namespace logging = com::sun::star::util::logging;
namespace LogLevel = logging::LogLevel;
/// class providing access to a log output sink in the context
class Logger
{
uno::Reference< logging::XLogger > m_xLogger;
public:
Logger() : m_xLogger() {}
Logger(uno::Reference< logging::XLogger > const & xLogger)
: m_xLogger(xLogger)
{}
explicit
Logger(uno::Reference< uno::XComponentContext > const & xContext)
: m_xLogger( getUnoLoggerFromContext(xContext) )
{}
sal_Int32 level() const
{ return m_xLogger.is() ? m_xLogger->getLevel() : LogLevel::OFF; }
bool isLogging(sal_Int32 nLogLevel) const
{ return m_xLogger.is() && m_xLogger->isLoggable(nLogLevel); }
/// log output to the logger
void log(sal_Int32 nLevel, const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const;
void log(sal_Int32 nLevel, const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const;
void error(const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::SEVERE, msg, sourceMethod, sourceClass); }
void error(const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::SEVERE, msg, sourceMethod, sourceClass); }
void warning(const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::WARNING, msg, sourceMethod, sourceClass); }
void warning(const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::WARNING, msg, sourceMethod, sourceClass); }
void info(const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::INFO, msg, sourceMethod, sourceClass); }
void info(const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::INFO, msg, sourceMethod, sourceClass); }
void config(const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::CONFIG, msg, sourceMethod, sourceClass); }
void config(const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::CONFIG, msg, sourceMethod, sourceClass); }
void fine(const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::FINE, msg, sourceMethod, sourceClass); }
void fine(const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::FINE, msg, sourceMethod, sourceClass); }
void finer(const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::FINER, msg, sourceMethod, sourceClass); }
void finer(const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::FINER, msg, sourceMethod, sourceClass); }
void finest(const rtl::OUString & msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::FINEST, msg, sourceMethod, sourceClass); }
void finest(const char * msg, const char * sourceMethod = 0, const char * sourceClass = 0) const
{ log( LogLevel::FINEST, msg, sourceMethod, sourceClass); }
uno::Reference< logging::XLogger > getUnoLogger() const { return m_xLogger; }
static
uno::Reference< logging::XLogger >
getUnoLoggerFromContext(uno::Reference< uno::XComponentContext > const & xContext);
};
// -----------------------------------------------------------------------------
} // namespace configmgr
#endif // CONFIGMGR_LOGGER_HXX