org.picocontainer.monitors.ConsoleComponentMonitor Maven / Gradle / Ivy
The newest version!
/*****************************************************************************
* Copyright (C) PicoContainer Organization. All rights reserved. *
* ------------------------------------------------------------------------- *
* The software in this package is published under the terms of the BSD *
* style license a copy of which has been included with this distribution in *
* the LICENSE.txt file. *
* *
* Original code by Paul Hammaant *
*****************************************************************************/
package org.picocontainer.monitors;
import static org.picocontainer.monitors.ComponentMonitorHelper.ctorToString;
import static org.picocontainer.monitors.ComponentMonitorHelper.format;
import static org.picocontainer.monitors.ComponentMonitorHelper.memberToString;
import static org.picocontainer.monitors.ComponentMonitorHelper.methodToString;
import static org.picocontainer.monitors.ComponentMonitorHelper.parmsToString;
import java.io.OutputStream;
import java.io.PrintStream;
import java.io.Serializable;
import java.lang.reflect.Constructor;
import java.lang.reflect.Member;
import java.lang.reflect.Method;
import org.picocontainer.ComponentAdapter;
import org.picocontainer.ComponentMonitor;
import org.picocontainer.MutablePicoContainer;
import org.picocontainer.PicoContainer;
import org.picocontainer.Injector;
import org.picocontainer.Behavior;
/**
* A {@link ComponentMonitor} which writes to a {@link OutputStream}.
* This is typically used to write to a console.
* (TODO After serialization, the output printstream is null)
*
* @author Paul Hammant
* @author Aslak Hellesøy
* @author Mauro Talevi
*/
@SuppressWarnings("serial")
public class ConsoleComponentMonitor implements ComponentMonitor, Serializable {
/**
* The outgoing print stream.
*/
private final transient PrintStream out;
/**
* Delegate component monitor (for component monitor chains).
*/
private final ComponentMonitor delegate;
/**
* Constructs a console component monitor that sends output to System.out.
*/
public ConsoleComponentMonitor() {
this(System.out);
}
/**
* Constructs a console component monitor that sends output to the specified output stream.
*
* @param out the designated output stream. Options include System.out, Socket streams, File streams,
* etc.
*/
public ConsoleComponentMonitor(OutputStream out) {
this(out, new NullComponentMonitor());
}
/**
* Constructs a console component monitor chain that sends output to the specified output stream
* and then sends all events to the delegate component monitor.
* @param out the output stream of choice.
* @param delegate the next monitor in the component monitor chain to receive event information.
*/
public ConsoleComponentMonitor(OutputStream out, ComponentMonitor delegate) {
this.out = new PrintStream(out);
this.delegate = delegate;
}
public Constructor instantiating(PicoContainer container, ComponentAdapter componentAdapter,
Constructor constructor
) {
out.println(format(ComponentMonitorHelper.INSTANTIATING, ctorToString(constructor)));
return delegate.instantiating(container, componentAdapter, constructor);
}
public void instantiated(PicoContainer container, ComponentAdapter componentAdapter,
Constructor constructor,
Object instantiated,
Object[] parameters,
long duration) {
out.println(format(ComponentMonitorHelper.INSTANTIATED, ctorToString(constructor), duration, instantiated.getClass().getName(), parmsToString(parameters)));
delegate.instantiated(container, componentAdapter, constructor, instantiated, parameters, duration);
}
public void instantiationFailed(PicoContainer container,
ComponentAdapter componentAdapter,
Constructor constructor,
Exception cause) {
out.println(format(ComponentMonitorHelper.INSTANTIATION_FAILED, ctorToString(constructor), cause.getMessage()));
delegate.instantiationFailed(container, componentAdapter, constructor, cause);
}
public Object invoking(PicoContainer container,
ComponentAdapter> componentAdapter,
Member member,
Object instance, Object[] args) {
out.println(format(ComponentMonitorHelper.INVOKING, memberToString(member), instance));
return delegate.invoking(container, componentAdapter, member, instance, args);
}
public void invoked(PicoContainer container,
ComponentAdapter> componentAdapter,
Member member,
Object instance,
long duration,
Object[] args, Object retVal) {
out.println(format(ComponentMonitorHelper.INVOKED, methodToString(member), instance, duration));
delegate.invoked(container, componentAdapter, member, instance, duration, args, retVal);
}
public void invocationFailed(Member member, Object instance, Exception cause) {
out.println(format(ComponentMonitorHelper.INVOCATION_FAILED, memberToString(member), instance, cause.getMessage()));
delegate.invocationFailed(member, instance, cause);
}
public void lifecycleInvocationFailed(MutablePicoContainer container,
ComponentAdapter> componentAdapter, Method method,
Object instance,
RuntimeException cause) {
out.println(format(ComponentMonitorHelper.LIFECYCLE_INVOCATION_FAILED, methodToString(method), instance, cause.getMessage()));
delegate.lifecycleInvocationFailed(container, componentAdapter, method, instance, cause);
}
public Object noComponentFound(MutablePicoContainer container, Object componentKey) {
out.println(format(ComponentMonitorHelper.NO_COMPONENT, componentKey));
return delegate.noComponentFound(container, componentKey);
}
public Injector newInjector(Injector injector) {
return delegate.newInjector(injector);
}
/** {@inheritDoc} **/
public Behavior newBehavior(Behavior behavior) {
return delegate.newBehavior(behavior);
}
}