KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > jcorporate > expresso > ext > struts > taglib > bean > ExDefineTag


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.struts.taglib.bean;
66
67 import com.jcorporate.expresso.core.misc.StringUtil;
68 import com.jcorporate.expresso.ext.struts.taglib.ControllerUtils;
69 import org.apache.log4j.Logger;
70 import org.apache.struts.taglib.bean.DefineTag;
71
72 import javax.servlet.jsp.JspException JavaDoc;
73 import javax.servlet.jsp.PageContext JavaDoc;
74
75
76 /**
77  * Define a scripting variable based on the value(s) of the specified
78  * bean property.
79  *
80  * @author Craig R. McClanahan
81  */

82 public class ExDefineTag extends DefineTag {
83     private static final Logger log = Logger.getLogger(ExDefineTag.class);
84
85
86     // --------------------------------------------------------- Public Methods
87
/**
88      * Retrieve the required property and expose it as a scripting variable.
89      *
90      * @return integer as defined in the standard tag library framework.
91      * @throws JspException if a JSP exception has occurred
92      */

93     public int doStartTag() throws JspException JavaDoc {
94         // Retrieve the required property value
95
if (log.isDebugEnabled()) {
96             log.debug("******** ExDefineTag.doStartTag()");
97         }
98
99         return (EVAL_BODY_TAG);
100     }
101
102
103     /**
104      * Retrieve the required property and expose it as a scripting variable.
105      *
106      * @throws JspException if a JSP exception has occurred
107      */

108     public int doEndTag() throws JspException JavaDoc {
109
110         if (log.isDebugEnabled()) {
111             log.debug("******** ExDefineTag.doEndTag()");
112         }
113
114         Object JavaDoc value = this.value;
115
116         if ((value == null) && (body != null)) {
117             // Allow body content to become the value if specified
118
value = body;
119         }
120         if (value == null) {
121
122             // Look up the requested property value
123
value = ControllerUtils.getBeanProperty(pageContext, name,
124                     property, false);
125         }
126         if (value == null) {
127             throw new JspException JavaDoc("Unable to find property '" +
128                     StringUtil.notNull(property) +
129                     "' in bean '" + StringUtil.notNull(name) +
130                     "'");
131         }
132
133         // Expose this value as a scripting variable
134
int inScope = PageContext.PAGE_SCOPE;
135
136         if ("request".equals(toScope)) {
137             inScope = PageContext.REQUEST_SCOPE;
138         } else if ("session".equals(toScope)) {
139             inScope = PageContext.SESSION_SCOPE;
140         } else if ("application".equals(toScope)) {
141             inScope = PageContext.APPLICATION_SCOPE;
142         }
143
144         pageContext.setAttribute(id, value, inScope);
145         // Continue processing this page
146
return (EVAL_PAGE);
147
148     }
149
150 }
151
Popular Tags