KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > jcorporate > expresso > ext > taglib > ContentTag


1 /* ====================================================================
2  * The Jcorporate Apache Style Software License, Version 1.2 05-07-2002
3  *
4  * Copyright (c) 1995-2002 Jcorporate Ltd. All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  *
10  * 1. Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  *
13  * 2. Redistributions in binary form must reproduce the above copyright
14  * notice, this list of conditions and the following disclaimer in
15  * the documentation and/or other materials provided with the
16  * distribution.
17  *
18  * 3. The end-user documentation included with the redistribution,
19  * if any, must include the following acknowledgment:
20  * "This product includes software developed by Jcorporate Ltd.
21  * (http://www.jcorporate.com/)."
22  * Alternately, this acknowledgment may appear in the software itself,
23  * if and wherever such third-party acknowledgments normally appear.
24  *
25  * 4. "Jcorporate" and product names such as "Expresso" must
26  * not be used to endorse or promote products derived from this
27  * software without prior written permission. For written permission,
28  * please contact info@jcorporate.com.
29  *
30  * 5. Products derived from this software may not be called "Expresso",
31  * or other Jcorporate product names; nor may "Expresso" or other
32  * Jcorporate product names appear in their name, without prior
33  * written permission of Jcorporate Ltd.
34  *
35  * 6. No product derived from this software may compete in the same
36  * market space, i.e. framework, without prior written permission
37  * of Jcorporate Ltd. For written permission, please contact
38  * partners@jcorporate.com.
39  *
40  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
41  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
42  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
43  * DISCLAIMED. IN NO EVENT SHALL JCORPORATE LTD OR ITS CONTRIBUTORS
44  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
45  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
46  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
47  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
48  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
49  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
50  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51  * SUCH DAMAGE.
52  * ====================================================================
53  *
54  * This software consists of voluntary contributions made by many
55  * individuals on behalf of the Jcorporate Ltd. Contributions back
56  * to the project(s) are encouraged when you make modifications.
57  * Please send them to support@jcorporate.com. For more information
58  * on Jcorporate Ltd. and its products, please see
59  * <http://www.jcorporate.com/>.
60  *
61  * Portions of this software are based upon other open source
62  * products and are subject to their respective licenses.
63  */

64
65 package com.jcorporate.expresso.ext.taglib;
66
67 import javax.servlet.jsp.JspException JavaDoc;
68 import javax.servlet.jsp.JspTagException JavaDoc;
69 import javax.servlet.jsp.JspWriter JavaDoc;
70 import javax.servlet.jsp.tagext.TagSupport JavaDoc;
71
72
73 /**
74  * ContentTag must be nested within an OutputTag tag. The ContentTag
75  * has no body, and simply displays the content from the parent
76  * OutputTag (Output.getContent()).
77  * <p/>
78  * Usage Example:
79  * </p><p>
80  * <expresso:OutputTag name="product"> <br />
81  * Content Area: <expresso:ContentTag /><br />
82  * Attribute: <expresso:AttributeTag name="product_desc"/> <br />
83  * Nested Output: <br /><expresso:OutputTag name="nestoutput"> <br />
84  * &nbsp; <expresso:ContentTag /> <br />
85  * </expresso:OutputTag> <br />
86  * </expresso:OutputTag> <br />
87  * <p/>
88  * </p>
89  *
90  * @author Adam Rossi, PlatinumSolutions
91  */

92 public class ContentTag
93         extends TagSupport JavaDoc {
94     private String JavaDoc content = null;
95
96     public ContentTag() {
97         super();
98     }
99
100     public int doStartTag() throws javax.servlet.jsp.JspException JavaDoc {
101         content = null;
102         return EVAL_BODY_INCLUDE;
103     }
104
105
106     /**
107      * Standard doEndTag.
108      *
109      * @return int
110      */

111     public int doEndTag()
112             throws javax.servlet.jsp.JspTagException JavaDoc {
113         try {
114
115             //Check to see if we have an ancestor
116
OutputTag ancestorOutput = (OutputTag) getAncestor("com.jcorporate.expresso.ext.taglib.OutputTag");
117
118             if (ancestorOutput == null) {
119                 throw new JspTagException JavaDoc("A ContentTag must be nested within a valid OutputTag.");
120             }
121
122             content = ancestorOutput.getContent();
123
124             JspWriter JavaDoc writer = pageContext.getOut();
125             writer.print(content);
126         } catch (Exception JavaDoc e) {
127             throw new JspTagException JavaDoc("ContentTag Error: " + e.getMessage());
128         }
129
130         return EVAL_PAGE;
131     } /* doEndTag() */
132
133
134     // convenience method for finding ancestor names with
135
// a specific class name
136
private TagSupport JavaDoc getAncestor(String JavaDoc className)
137             throws JspException JavaDoc {
138         Class JavaDoc klass = null; // can't name variable "class"
139

140         try {
141             klass = Class.forName(className);
142         } catch (ClassNotFoundException JavaDoc ex) {
143             throw new JspException JavaDoc(ex.getMessage());
144         }
145
146         return (TagSupport JavaDoc) findAncestorWithClass(this, klass);
147     }
148 }
Popular Tags