001    /**
002     * Licensed to the Apache Software Foundation (ASF) under one or more
003     * contributor license agreements.  See the NOTICE file distributed with
004     * this work for additional information regarding copyright ownership.
005     * The ASF licenses this file to You under the Apache License, Version 2.0
006     * (the "License"); you may not use this file except in compliance with
007     * the License.  You may obtain a copy of the License at
008     *
009     *      http://www.apache.org/licenses/LICENSE-2.0
010     *
011     * Unless required by applicable law or agreed to in writing, software
012     * distributed under the License is distributed on an "AS IS" BASIS,
013     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014     * See the License for the specific language governing permissions and
015     * limitations under the License.
016     */
017    package org.apache.camel.model;
018    
019    import java.util.ArrayList;
020    import java.util.List;
021    
022    import javax.xml.bind.annotation.XmlAccessType;
023    import javax.xml.bind.annotation.XmlAccessorType;
024    import javax.xml.bind.annotation.XmlElementRef;
025    import javax.xml.bind.annotation.XmlType;
026    
027    import org.apache.commons.logging.Log;
028    import org.apache.commons.logging.LogFactory;
029    
030    /**
031     * A useful base class for output types
032     *
033     * @version $Revision: 69900 $
034     */
035    @XmlType(name = "outputType")
036    @XmlAccessorType(XmlAccessType.FIELD)
037    public class OutputType<Type extends ProcessorType> extends ProcessorType<Type> {
038        private static final transient Log LOG = LogFactory.getLog(OutputType.class);
039    
040        @XmlElementRef
041        protected List<ProcessorType<?>> outputs = new ArrayList<ProcessorType<?>>();
042    
043        public List<ProcessorType<?>> getOutputs() {
044            return outputs;
045        }
046    
047        public void setOutputs(List<ProcessorType<?>> outputs) {
048            this.outputs = outputs;
049            if (outputs != null) {
050                for (ProcessorType output : outputs) {
051                    configureChild(output);
052                }
053            }
054        }
055    
056    
057        @Override
058        protected void configureChild(ProcessorType output) {
059            super.configureChild(output);
060            if (isInheritErrorHandler()) {
061                output.setErrorHandlerBuilder(getErrorHandlerBuilder());
062            }
063            // don't inherit interceptors by default
064        }
065    }