KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > caucho > jstl > rt > SqlDateParamTag


1 /*
2  * Copyright (c) 1998-2006 Caucho Technology -- all rights reserved
3  *
4  * This file is part of Resin(R) Open Source
5  *
6  * Each copy or derived work must preserve the copyright notice and this
7  * notice unmodified.
8  *
9  * Resin Open Source is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * Resin Open Source is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
17  * of NON-INFRINGEMENT. See the GNU General Public License for more
18  * details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with Resin Open Source; if not, write to the
22  * Free SoftwareFoundation, Inc.
23  * 59 Temple Place, Suite 330
24  * Boston, MA 02111-1307 USA
25  *
26  * @author Scott Ferguson
27  */

28
29 package com.caucho.jstl.rt;
30
31 import com.caucho.util.L10N;
32
33 import javax.servlet.jsp.JspException JavaDoc;
34 import javax.servlet.jsp.jstl.sql.SQLExecutionTag;
35 import javax.servlet.jsp.tagext.Tag JavaDoc;
36 import javax.servlet.jsp.tagext.TagSupport JavaDoc;
37
38 /**
39  * Looks up an i18n message from a bundle and prints it.
40  */

41 public class SqlDateParamTag extends TagSupport JavaDoc {
42   private static L10N L = new L10N(SqlDateParamTag.class);
43   
44   private Object JavaDoc _value;
45   private String JavaDoc _type;
46
47   /**
48    * Sets the value
49    *
50    * @param value the sql value.
51    */

52   public void setValue(Object JavaDoc value)
53   {
54     _value = value;
55   }
56
57   /**
58    * Sets the type
59    *
60    * @param type the type.
61    */

62   public void setType(String JavaDoc type)
63   {
64     _type = type;
65   }
66
67   /**
68    * Process the tag.
69    */

70   public int doStartTag()
71     throws JspException JavaDoc
72   {
73     Object JavaDoc value = _value;
74
75     long time = 0;
76
77     Object JavaDoc result = null;
78
79     if (value == null) {
80     }
81     else if (value instanceof Number JavaDoc)
82       time = ((Number JavaDoc) value).longValue();
83     else if (value instanceof java.util.Date JavaDoc)
84       time = ((java.util.Date JavaDoc) value).getTime();
85     else if (value instanceof java.sql.Date JavaDoc)
86       time = ((java.sql.Date JavaDoc) value).getTime();
87     else
88       throw new JspException JavaDoc(L.l("sql:dateParam requires at date at `{0}'", value));
89
90     if (value == null)
91       result = null;
92     else if (_type == null)
93       result = new java.sql.Timestamp JavaDoc(time);
94     else if (_type.equals("time"))
95       result = new java.sql.Time JavaDoc(time);
96     else if (_type.equals("date"))
97       result = new java.sql.Date JavaDoc(time);
98     else
99       result = new java.sql.Timestamp JavaDoc(time);
100
101     Tag parent = getParent();
102     for (;
103          parent != null && ! (parent instanceof SQLExecutionTag);
104          parent = parent.getParent()) {
105     }
106
107     if (parent == null)
108       throw new JspException JavaDoc(L.l("sql:dateParam requires sql:query parent."));
109
110     SQLExecutionTag tag = (SQLExecutionTag) parent;
111
112     tag.addSQLParameter(result);
113     
114     return SKIP_BODY;
115   }
116 }
117
Popular Tags