001    package org.apache.myfaces.tobago.lifecycle;
002    
003    /*
004     * Licensed to the Apache Software Foundation (ASF) under one or more
005     * contributor license agreements.  See the NOTICE file distributed with
006     * this work for additional information regarding copyright ownership.
007     * The ASF licenses this file to You under the Apache License, Version 2.0
008     * (the "License"); you may not use this file except in compliance with
009     * the License.  You may obtain a copy of the License at
010     *
011     *      http://www.apache.org/licenses/LICENSE-2.0
012     *
013     * Unless required by applicable law or agreed to in writing, software
014     * distributed under the License is distributed on an "AS IS" BASIS,
015     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016     * See the License for the specific language governing permissions and
017     * limitations under the License.
018     */
019    
020    import org.apache.commons.logging.Log;
021    import org.apache.commons.logging.LogFactory;
022    
023    import javax.faces.lifecycle.LifecycleFactory;
024    import javax.faces.lifecycle.Lifecycle;
025    import java.util.Iterator;
026    
027    public class TobagoLifecycleFactory extends LifecycleFactory {
028    
029      private static final Log LOG = LogFactory.getLog(TobagoLifecycleFactory.class);
030    
031      private LifecycleFactory factory;
032      private TobagoLifecycle defaultLifecycle;
033    
034      public TobagoLifecycleFactory(LifecycleFactory factory) {
035        this.factory = factory;
036        defaultLifecycle = new TobagoLifecycle();
037        if (LOG.isInfoEnabled()) {
038          LOG.info("new TobagoLifecycleFactory");
039        }
040      }
041    
042      public void addLifecycle(String lifecycleId, Lifecycle lifecycle) {
043        factory.addLifecycle(lifecycleId, lifecycle);
044        if (LOG.isInfoEnabled()) {
045          LOG.info("Lifecycle added : " + lifecycleId + " = " + lifecycle.getClass().getName() + "");
046        }
047      }
048    
049      public Lifecycle getLifecycle(String lifecycleId) {
050        if (LifecycleFactory.DEFAULT_LIFECYCLE.equals(lifecycleId)) {
051          if (LOG.isInfoEnabled()) {
052            LOG.info("getLifecycle(\"" + lifecycleId + "\")  -> TobagoLifecycle");
053          }
054          return defaultLifecycle;
055        } else {
056          if (LOG.isInfoEnabled()) {
057            LOG.info("getLifecycle(\"" + lifecycleId + "\")  -> other Lifecycle");
058          }
059          return factory.getLifecycle(lifecycleId);
060        }
061      }
062    
063      public Iterator getLifecycleIds() {
064        if (LOG.isInfoEnabled()) {
065          LOG.info("getLifecycleIds()");
066        }
067        return factory.getLifecycleIds();
068      }
069    }