Copyright (c) 2006, 2016 Cognos Incorporated, IBM Corporation and others This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0 which accompanies this distribution, and is available at https://www.eclipse.org/legal/epl-2.0/ SPDX-License-Identifier: EPL-2.0
/******************************************************************************* * Copyright (c) 2006, 2016 Cognos Incorporated, IBM Corporation and others * * This program and the accompanying materials are made * available under the terms of the Eclipse Public License 2.0 which * accompanies this distribution, and is available at * https://www.eclipse.org/legal/epl-2.0/ * * SPDX-License-Identifier: EPL-2.0 ******************************************************************************/
package org.eclipse.osgi.internal.log; import java.util.*; import org.eclipse.equinox.log.ExtendedLogReaderService; import org.eclipse.equinox.log.LogFilter; import org.osgi.service.log.LogEntry; import org.osgi.service.log.LogListener; public class ExtendedLogReaderServiceImpl implements ExtendedLogReaderService { private final ExtendedLogReaderServiceFactory factory; private Set<LogListener> listeners = new HashSet<>(); ExtendedLogReaderServiceImpl(ExtendedLogReaderServiceFactory factory) { this.factory = factory; } @Override public synchronized void addLogListener(LogListener listener, LogFilter filter) { checkShutdown(); if (listener == null) throw new IllegalArgumentException("LogListener must not be null"); //$NON-NLS-1$ if (filter == null) throw new IllegalArgumentException("LogFilter must not be null"); //$NON-NLS-1$ listeners.add(listener); factory.addLogListener(listener, filter); } @Override public void addLogListener(LogListener listener) { addLogListener(listener, ExtendedLogReaderServiceFactory.NULL_LOGGER_FILTER); } @Override public Enumeration<LogEntry> getLog() { checkShutdown(); return factory.getLog(); } @Override public synchronized void removeLogListener(LogListener listener) { checkShutdown(); if (listener == null) throw new IllegalArgumentException("LogListener must not be null"); //$NON-NLS-1$ factory.removeLogListener(listener); listeners.remove(listener); } private synchronized void checkShutdown() { if (listeners == null) throw new IllegalStateException("LogReaderService is shutdown."); //$NON-NLS-1$ } synchronized void shutdown() { for (LogListener listener : listeners) { factory.removeLogListener(listener); } listeners = null; } }