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 }