Save This Page
Home » mojarra-1.2_09-b02-FCS-source » com.sun.faces.lifecycle » [javadoc | source]
    1   /*
    2    * $Id: ProcessValidationsPhase.java,v 1.30 2007/07/19 15:01:56 rlubke Exp $
    3    */
    4   
    5   /*
    6    * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
    7    * 
    8    * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
    9    * 
   10    * The contents of this file are subject to the terms of either the GNU
   11    * General Public License Version 2 only ("GPL") or the Common Development
   12    * and Distribution License("CDDL") (collectively, the "License").  You
   13    * may not use this file except in compliance with the License. You can obtain
   14    * a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
   15    * or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific
   16    * language governing permissions and limitations under the License.
   17    * 
   18    * When distributing the software, include this License Header Notice in each
   19    * file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
   20    * Sun designates this particular file as subject to the "Classpath" exception
   21    * as provided by Sun in the GPL Version 2 section of the License file that
   22    * accompanied this code.  If applicable, add the following below the License
   23    * Header, with the fields enclosed by brackets [] replaced by your own
   24    * identifying information: "Portions Copyrighted [year]
   25    * [name of copyright owner]"
   26    * 
   27    * Contributor(s):
   28    * 
   29    * If you wish your version of this file to be governed by only the CDDL or
   30    * only the GPL Version 2, indicate your decision by adding "[Contributor]
   31    * elects to include this software in this distribution under the [CDDL or GPL
   32    * Version 2] license."  If you don't indicate a single choice of license, a
   33    * recipient has the option to distribute your version of this file under
   34    * either the CDDL, the GPL Version 2 or to extend the choice of license to
   35    * its licensees as provided above.  However, if you add GPL Version 2 code
   36    * and therefore, elected the GPL Version 2 license, then the option applies
   37    * only if the new code is made subject to such option by the copyright
   38    * holder.
   39    */
   40   
   41   package com.sun.faces.lifecycle;
   42   
   43   import javax.faces.FacesException;
   44   import javax.faces.component.UIComponent;
   45   import javax.faces.context.FacesContext;
   46   import javax.faces.event.PhaseId;
   47   
   48   import java.util.logging.Logger;
   49   import java.util.logging.Level;
   50   
   51   import com.sun.faces.util.FacesLogger;
   52   
   53   /**
   54    * ProcessValidationsPhase executes <code>processValidators</code> on each
   55    * component in the tree.
   56    */
   57   public class ProcessValidationsPhase extends Phase {
   58   
   59   
   60       // Log instance for this class
   61       private static Logger LOGGER = FacesLogger.LIFECYCLE.getLogger();
   62   
   63   
   64       // ---------------------------------------------------------- Public Methods
   65   
   66   
   67       public void execute(FacesContext facesContext) throws FacesException {
   68   
   69           if (LOGGER.isLoggable(Level.FINE)) {
   70               LOGGER.fine("Entering ProcessValidationsPhase");
   71           }
   72           UIComponent component = facesContext.getViewRoot();
   73           assert (null != component);
   74   
   75           try {
   76               component.processValidators(facesContext);
   77           } catch (RuntimeException re) {
   78               String exceptionMessage = re.getMessage();
   79               if (null != exceptionMessage) {
   80                   if (LOGGER.isLoggable(Level.WARNING)) {
   81                       LOGGER.log(Level.WARNING, exceptionMessage, re);
   82                   }
   83               }
   84               throw new FacesException(exceptionMessage, re);
   85           }
   86           if (LOGGER.isLoggable(Level.FINE)) {
   87               LOGGER.fine("Exiting ProcessValidationsPhase");
   88           }
   89   
   90       }
   91   
   92   
   93       public PhaseId getId() {
   94   
   95           return PhaseId.PROCESS_VALIDATIONS;
   96   
   97       }
   98   
   99   
  100   // The testcase for this class is TestProcessValidationsPhase.java
  101   
  102   } // end of class ProcessValidationsPhase

Save This Page
Home » mojarra-1.2_09-b02-FCS-source » com.sun.faces.lifecycle » [javadoc | source]