/*******************************************************************************
* Copyright (c) 2007, 2014 compeople AG and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* compeople AG - initial API and implementation
*******************************************************************************/
package org.eclipse.riena.internal.core.logging;
import java.lang.reflect.Proxy;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.LinkedBlockingQueue;
import org.eclipse.core.runtime.jobs.Job;
import org.eclipse.equinox.log.Logger;
/**
* This logger factory creates a {@code Logger} that collects log events until a
* <i>real</i> logger is available. The collected log events will than be
* delivered by the <i>real</i> logger within a worker thread.
*/
public final class DeferringLoggerFactory {
private static Job forwarder;
private static BlockingQueue<DeferredLogEvent> queue;
private DeferringLoggerFactory() {
// utility
}
public static Logger createLogger(final String name, final LoggerProvider loggerProvider) {
synchronized (DeferringLoggerFactory.class) {
if (queue == null) {
queue = new LinkedBlockingQueue<DeferredLogEvent>();
forwarder = new DeferredLoggingForwarder(loggerProvider, queue);
forwarder.schedule();
}
}
return (Logger) Proxy.newProxyInstance(Logger.class.getClassLoader(), new Class<?>[] { Logger.class },
new DeferringLoggerHandler(name, loggerProvider, queue));
}
}