![JAR search and dependency download from the Maven repository](/logo.png)
flex.messaging.log.Logger Maven / Gradle / Ivy
Go to download
BlazeDS is the server-based Java remoting and web messaging technology that enables developers to easily connect to back-end distributed data and push data in real-time to Adobe Flex and Adobe AIR applications for more responsive rich Internet application (RIA) experiences.
/*************************************************************************
*
* ADOBE CONFIDENTIAL
* __________________
*
* [2002] - [2007] Adobe Systems Incorporated
* All Rights Reserved.
*
* NOTICE: All information contained herein is, and remains
* the property of Adobe Systems Incorporated and its suppliers,
* if any. The intellectual and technical concepts contained
* herein are proprietary to Adobe Systems Incorporated
* and its suppliers and may be covered by U.S. and Foreign Patents,
* patents in process, and are protected by trade secret or copyright law.
* Dissemination of this information or reproduction of this material
* is strictly forbidden unless prior written permission is obtained
* from Adobe Systems Incorporated.
*/
package flex.messaging.log;
import java.util.Iterator;
import java.util.ArrayList;
import flex.messaging.util.PrettyPrinter;
import flex.messaging.util.StringUtils;
/**
* The Logger
class is used to log out information. It provides named
* methods to log information out at the desired level. Each Logger
* will log information out for a log category that is settable.
*/
public class Logger
{
/**
* The category this logger send messages for.
*/
private volatile String category;
/**
* The list of targets that this logger will dispatch log events to.
*/
private final ArrayList targets;
/**
* Constructs a Logger
instance that will log
* information out to the specified category.
*
* @param category The category to log information for.
*/
public Logger(String category)
{
this.category = category;
targets = new ArrayList();
}
/**
* Returns the category this Logger
logs information for.
*
* @return The category this Logger
logs information for.
*/
public String getCategory()
{
return category;
}
/**
* Adds a Target
that will format and output log events
* generated by this Logger
.
*
* @param target The Target
to add.
*/
void addTarget(Target target)
{
synchronized (targets)
{
if (!targets.contains(target))
targets.add(target);
}
}
/**
* Removes a Target
from this Logger
.
*
* @param target The Target
to remove.
*/
void removeTarget(Target target)
{
synchronized (targets)
{
targets.remove(target);
}
}
/*
* DEBUG
*/
/**
* Logs out a debug message.
*
* @param message The message to log.
*/
public void debug(String message)
{
log(LogEvent.DEBUG, message, null, null);
}
/**
* Logs out a debug message associated with a Throwable
.
*
* @param message The message to log.
* @param t The associated Throwable
.
*/
public void debug(String message, Throwable t)
{
log(LogEvent.DEBUG, message, null, t);
}
/**
* Logs out a debug message supporting positional parameter substitutions.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
*/
public void debug(String message, Object[] parameters)
{
log(LogEvent.DEBUG, message, parameters, null);
}
/**
* Logs out a debug message supporting positional parameter substitutions and an
* associated Throwable
.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
* @param t The associated Throwable
.
*/
public void debug(String message, Object[] parameters, Throwable t)
{
log(LogEvent.DEBUG, message, parameters, t);
}
/*
* INFO
*/
/**
* Logs out an info message.
*
* @param message The message to log.
*/
public void info(String message)
{
log(LogEvent.INFO, message, null, null);
}
/**
* Logs out an info message associated with a Throwable
.
*
* @param message The message to log.
* @param t The associated Throwable
.
*/
public void info(String message, Throwable t)
{
log(LogEvent.INFO, message, null, t);
}
/**
* Logs out an info message supporting positional parameter substitutions.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
*/
public void info(String message, Object[] parameters)
{
log(LogEvent.INFO, message, parameters, null);
}
/**
* Logs out an info message supporting positional parameter substitutions and an
* associated Throwable
.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
* @param t The associated Throwable
.
*/
public void info(String message, Object[] parameters, Throwable t)
{
log(LogEvent.INFO, message, parameters, t);
}
/*
* WARN
*/
/**
* Logs out a warn message.
*
* @param message The message to log.
*/
public void warn(String message)
{
log(LogEvent.WARN, message, null, null);
}
/**
* Logs out a warn message associated with a Throwable
.
*
* @param message The message to log.
* @param t The associated Throwable
.
*/
public void warn(String message, Throwable t)
{
log(LogEvent.WARN, message, null, t);
}
/**
* Logs out a warn message supporting positional parameter substitutions.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
*/
public void warn(String message, Object[] parameters)
{
log(LogEvent.WARN, message, parameters, null);
}
/**
* Logs out a warn message supporting positional parameter substitutions and an
* associated Throwable
.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
* @param t The associated Throwable
.
*/
public void warn(String message, Object[] parameters, Throwable t)
{
log(LogEvent.WARN, message, parameters, t);
}
/*
* ERROR
*/
/**
* Logs out an error message.
*
* @param message The message to log.
*/
public void error(String message)
{
log(LogEvent.ERROR, message, null, null);
}
/**
* Logs out an error message associated with a Throwable
.
*
* @param message The message to log.
* @param t The associated Throwable
.
*/
public void error(String message, Throwable t)
{
log(LogEvent.ERROR, message, null, t);
}
/**
* Logs out an error message supporting positional parameter substitutions.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
*/
public void error(String message, Object[] parameters)
{
log(LogEvent.ERROR, message, parameters, null);
}
/**
* Logs out an error message supporting positional parameter substitutions and an
* associated Throwable
.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
* @param t The associated Throwable
.
*/
public void error(String message, Object[] parameters, Throwable t)
{
log(LogEvent.ERROR, message, parameters, t);
}
/*
* FATAL
*/
/**
* Logs out a fatal message.
*
* @param message The message to log.
*/
public void fatal(String message)
{
log(LogEvent.FATAL, message, null, null);
}
/**
* Logs out a fatal message associated with a Throwable
.
*
* @param message The message to log.
* @param t The associated Throwable
.
*/
public void fatal(String message, Throwable t)
{
log(LogEvent.FATAL, message, null, t);
}
/**
* Logs out a fatal message supporting positional parameter substitutions.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
*/
public void fatal(String message, Object[] parameters)
{
log(LogEvent.FATAL, message, parameters, null);
}
/**
* Logs out a fatal message supporting positional parameter substitutions and an
* associated Throwable
.
*
* @param message The message to log.
* @param parameters Parameters to substitute into the message.
* @param t The associated Throwable
.
*/
public void fatal(String message, Object[] parameters, Throwable t)
{
log(LogEvent.FATAL, message, parameters, t);
}
/**
* @exclude
* The methods named according to log level delegate to this method to log.
*
* @param level The log level.
* @param message The message to log.
* @param parameters Substitution parameters (may be null).
* @param t The associated Throwable
(may be null).
*/
public void log(short level, String message, Object[] parameters, Throwable t)
{
log(level, message, parameters, t, true);
}
/**
* @exclude
* Logs a passed message if its level verifies as high enough.
*
* @param level The log level.
* @param message The message to log.
* @param parameters Substitution parameters (may be null).
* @param t The associated Throwable
.
* @param verifyLevel true
to verify the log level; otherwise log without verifying the level.
*/
public void log(short level, String message, Object[] parameters, Throwable t, boolean verifyLevel)
{
if (targets.size() > 0 && (!verifyLevel || (level >= Log.getTargetLevel())))
{
if (parameters != null)
{
PrettyPrinter prettyPrinter = Log.getPrettyPrinter();
// replace all of the parameters in the msg string
for(int i = 0; i < parameters.length; i++)
{
String replacement = parameters[i] != null ? prettyPrinter.prettify(parameters[i]) : "null";
//this guy runs into problems if the replacement has a \ or $ in it
//message = message.replaceAll("\\{" + i + "\\}", replacement);
message = StringUtils.substitute(message, "{" + i + "}", replacement);
}
}
LogEvent event = new LogEvent(this, message, level, t);
Target tgt;
synchronized (targets)
{
for (Iterator iter = targets.iterator(); iter.hasNext();)
{
tgt = (Target)iter.next();
if (!verifyLevel || (level >= tgt.getLevel()))
tgt.logEvent(event);
}
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy