BodyTagSupport.java
上传用户:sxlinghang
上传日期:2022-07-20
资源大小:1405k
文件大小:6k
源码类别:

数据库编程

开发平台:

Java

  1. /*
  2.  * The Apache Software License, Version 1.1
  3.  *
  4.  * Copyright (c) 1999 The Apache Software Foundation.  All rights 
  5.  * reserved.
  6.  *
  7.  * Redistribution and use in source and binary forms, with or without
  8.  * modification, are permitted provided that the following conditions
  9.  * are met:
  10.  *
  11.  * 1. Redistributions of source code must retain the above copyright
  12.  *    notice, this list of conditions and the following disclaimer. 
  13.  *
  14.  * 2. Redistributions in binary form must reproduce the above copyright
  15.  *    notice, this list of conditions and the following disclaimer in
  16.  *    the documentation and/or other materials provided with the
  17.  *    distribution.
  18.  *
  19.  * 3. The end-user documentation included with the redistribution, if
  20.  *    any, must include the following acknowlegement:  
  21.  *       "This product includes software developed by the 
  22.  *        Apache Software Foundation (http://www.apache.org/)."
  23.  *    Alternately, this acknowlegement may appear in the software itself,
  24.  *    if and wherever such third-party acknowlegements normally appear.
  25.  *
  26.  * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
  27.  *    Foundation" must not be used to endorse or promote products derived
  28.  *    from this software without prior written permission. For written 
  29.  *    permission, please contact apache@apache.org.
  30.  *
  31.  * 5. Products derived from this software may not be called "Apache"
  32.  *    nor may "Apache" appear in their names without prior written
  33.  *    permission of the Apache Group.
  34.  *
  35.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  36.  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  37.  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  38.  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  39.  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40.  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  41.  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  42.  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  43.  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  44.  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  45.  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  46.  * SUCH DAMAGE.
  47.  * ====================================================================
  48.  *
  49.  * This software consists of voluntary contributions made by many
  50.  * individuals on behalf of the Apache Software Foundation.  For more
  51.  * information on the Apache Software Foundation, please see
  52.  * <http://www.apache.org/>.
  53.  *
  54.  */
  55. package javax.servlet.jsp.tagext;
  56. import javax.servlet.jsp.*;
  57. import javax.servlet.jsp.tagext.*;
  58. import javax.servlet.*;
  59. import java.io.Writer;
  60. import java.util.Hashtable;
  61. /**
  62.  * Actions in a Tag Library are defined through subclasses of Tag.
  63.  */
  64. public class BodyTagSupport extends TagSupport implements BodyTag {
  65.     /**
  66.      * Default constructor, all subclasses are required to only define
  67.      * a public constructor with the same signature, and to call the
  68.      * superclass constructor.
  69.      *
  70.      * This constructor is called by the code generated by the JSP
  71.      * translator.
  72.      *
  73.      */
  74.     public BodyTagSupport() {
  75. super();
  76.     }
  77.     /**
  78.      * Process the start tag for this instance.
  79.      *
  80.      * The doStartTag() method assumes that all setter methods have been
  81.      * invoked before.
  82.      *
  83.      * When this method is invoked, the body has not yet been invoked.
  84.      *
  85.      * @returns EVAL_BODY_TAG if the tag wants to process body, SKIP_BODY if it
  86.      * does ont want to process it.
  87.      */
  88.  
  89.     public int doStartTag() throws JspException {
  90.         return EVAL_BODY_TAG;
  91.     }
  92.     /**
  93.      * Process the end tag. This method will be called on all Tag objects.
  94.      *
  95.      * All instance state associated with this instance must be reset.
  96.      * The release() method should be called after this invocation.
  97.      */
  98.     public int doEndTag() throws JspException {
  99. return super.doEndTag();
  100.     }
  101.     // Actions related to body evaluation
  102.     /**
  103.      * Prepare for evaluation of the body
  104.      * It will be invoked at most once per action invocation.
  105.      * Will not be invoked if there is no body evaluation.
  106.      *
  107.      * Frequently it is not redefined by Tag author.
  108.      *
  109.      * @param b the BodyContent
  110.      * @seealso #doAfterBody
  111.      */
  112.     public void setBodyContent(BodyContent b) {
  113. this.bodyContent = b;
  114.     }
  115.     /**
  116.      * Prepare for evaluation of the body
  117.      * It will be invoked at most once per action invocation.
  118.      * Will not be invoked if there is no body evaluation.
  119.      *
  120.      * Frequently it is not redefined by Tag author.
  121.      *
  122.      * @seealso #doAfterBody
  123.      */
  124.     public void doInitBody() throws JspException {
  125.     }
  126.     /**
  127.      * Actions after some body has been evaluated.
  128.      *
  129.      * Not invoked in empty tags or in tags returning SKIP_BODY in doStartTag()
  130.      * This method is invoked after every body evaluation.
  131.      * The pair "BODY -- doAfterBody()" is invoked initially if doStartTag()
  132.      * returned EVAL_BODY_TAG, and it is repeated as long
  133.      * as the doAfterBody() evaluation returns EVAL_BODY_TAG
  134.      * <p>
  135.      * The method re-invocations may be lead to different actions because
  136.      * there might have been some changes to shared state, or because
  137.      * of external computation.
  138.      *
  139.      * @returns whether additional evaluations of the body are desired
  140.      * @seealso #doInitBody
  141.      */
  142.     public int doAfterBody() throws JspException {
  143.   return SKIP_BODY;
  144.     }
  145.     /**
  146.      * reset the state of the Tag
  147.      */
  148.     public void release() {
  149. bodyContent = null;
  150. super.release();
  151.     }
  152.     /**
  153.      * Get current bodyContent
  154.      */
  155.     
  156.     public BodyContent getBodyContent() {
  157. return bodyContent;
  158.     }
  159.     /**
  160.      * Get surrounding out
  161.      */
  162.     public JspWriter getPreviousOut() {
  163. return bodyContent.getEnclosingWriter();
  164.     }
  165.     // protected fields
  166.     protected BodyContent   bodyContent;
  167. }