blob: efdac2b9504d9fb55e914c8eda1591e39b70ac90 [file] [log] [blame]
/*
* Copyright (C) 2012 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.motorola.studio.android.logger.collector.util;
import java.util.HashMap;
import java.util.Map;
import com.motorola.studio.android.logger.Logger;
/**
* Class with useful methods to log errors.
*/
public class PlatformLogger
{
/**
* Logger for this class.
*/
private final Logger logger;
/**
* Shared instances by Class
*/
private static Map<Class<? extends Object>, PlatformLogger> instances =
new HashMap<Class<? extends Object>, PlatformLogger>();
/**
* Default constructor
*
* @param clazz Class to be logged.
*/
private PlatformLogger(Class<? extends Object> clazz)
{
this.logger = Logger.getLogger(clazz.getName());
}
/**
* Returns an instance by a given class object.
*
* @param clazz The given class.
* @return an instance by a given class object.
*/
public static synchronized PlatformLogger getInstance(Class<? extends Object> clazz)
{
PlatformLogger instance = instances.get(clazz);
if (instance == null)
{
instance = new PlatformLogger(clazz);
instances.put(clazz, instance);
}
return instance;
}
/**
* Log a message object with the DEBUG level.
*
* @param message The message to log.
*/
public void debug(String message)
{
debug(message, null);
}
/**
* Log a message object with the DEBUG level.
*
* @param message The message to log.
* @param exception Exception whose stack will be logged.
*/
public void debug(String message, Throwable exception)
{
if (null == exception)
{
logger.debug(message);
}
else
{
logger.debug(message, exception);
}
}
/**
* Log a message object with the WARN level.
*
* @param message The message to log.
*/
public void warn(String message)
{
warn(message, null);
}
/**
* Log a message object with the WARN level.
*
* @param message The message to log.
* @param exception Exception whose stack will be logged.
*/
public void warn(String message, Throwable exception)
{
if (null == exception)
{
logger.warn(message);
}
else
{
logger.warn(message, exception);
}
}
/**
* Log a message object with the FATAL level.
*
* @param message The message to log.
*/
public void fatal(String message)
{
fatal(message, null);
}
/**
* Log a message object with the FATAL level.
*
* @param message The message to log.
* @param exception Exception whose stack will be logged.
*/
public void fatal(String message, Throwable exception)
{
if (null == exception)
{
logger.fatal(message);
}
else
{
logger.fatal(message, exception);
}
}
/**
* Log a message object with the INFO level.
*
* @param message The message to log.
*/
public void info(String message)
{
info(message, null);
}
/**
* Log a message object with the INFO level.
*
* @param message The message to log.
* @param exception Exception whose stack will be logged.
*/
public void info(String message, Throwable exception)
{
if (null == exception)
{
logger.info(message);
}
else
{
logger.info(message, exception);
}
}
/**
* Log a message object with the ERROR level.
*
* @param message The message to log.
*/
public void error(String message)
{
this.logger.error(message);
}
/**
* Log a message object with the ERROR level.
*
* @param message The message to log.
* @param exception Exception whose stack will be logged.
*/
public void error(String message, Throwable exception)
{
this.logger.error(message, exception);
}
}