/* * Copyright 2006-2007 the original author or authors. * * 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 org.springframework.batch.item.support; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import org.springframework.batch.item.ExecutionContext; import org.springframework.batch.item.ItemStream; import org.springframework.batch.item.ItemStreamException; /** * Simple {@link ItemStream} that delegates to a list of other streams. * * @author Dave Syer * */ public class CompositeItemStream implements ItemStream { private List<ItemStream> streams = new ArrayList<ItemStream>(); /** * Public setter for the listeners. * * @param listeners */ public void setStreams(ItemStream[] listeners) { this.streams = Arrays.asList(listeners); } /** * Register a {@link ItemStream} as one of the interesting providers under * the provided key. * */ public void register(ItemStream stream) { synchronized (streams) { if (!streams.contains(stream)) { streams.add(stream); } } } /** * */ public CompositeItemStream() { super(); } /** * Simple aggregate {@link ExecutionContext} provider for the contributions * registered under the given key. * * @see org.springframework.batch.item.ItemStream#update(ExecutionContext) */ @Override public void update(ExecutionContext executionContext) { for (ItemStream itemStream : streams) { itemStream.update(executionContext); } } /** * Broadcast the call to close. * @throws ItemStreamException */ @Override public void close() throws ItemStreamException { for (ItemStream itemStream : streams) { itemStream.close(); } } /** * Broadcast the call to open. * @throws ItemStreamException */ @Override public void open(ExecutionContext executionContext) throws ItemStreamException { for (ItemStream itemStream : streams) { itemStream.open(executionContext); } } }