KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > groovy > lang > MetaBeanProperty


1 /*
2  * $Id: MetaBeanProperty.java,v 1.3 2005/01/10 21:22:12 glaforge Exp $
3  *
4  * Copyright 2003 (C) James Strachan and Bob Mcwhirter. All Rights Reserved.
5  *
6  * Redistribution and use of this software and associated documentation
7  * ("Software"), with or without modification, are permitted provided that the
8  * following conditions are met:
9  * 1. Redistributions of source code must retain copyright statements and
10  * notices. Redistributions must also contain a copy of this document.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in the
13  * documentation and/or other materials provided with the distribution.
14  * 3. The name "groovy" must not be used to endorse or promote products
15  * derived from this Software without prior written permission of The Codehaus.
16  * For written permission, please contact info@codehaus.org.
17  * 4. Products derived from this Software may not be called "groovy" nor may
18  * "groovy" appear in their names without prior written permission of The
19  * Codehaus. "groovy" is a registered trademark of The Codehaus.
20  * 5. Due credit should be given to The Codehaus - http://groovy.codehaus.org/
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE CODEHAUS AND CONTRIBUTORS ``AS IS'' AND ANY
23  * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
24  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25  * DISCLAIMED. IN NO EVENT SHALL THE CODEHAUS OR ITS CONTRIBUTORS BE LIABLE FOR
26  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
32  * DAMAGE.
33  *
34  */

35 package groovy.lang;
36
37 /**
38  * Represents a property on a bean which may have a getter and/or a setter
39  *
40  * @author <a HREF="mailto:james@coredevelopers.net">James Strachan</a>
41  * @author Kim Pilho
42  * @version $Revision: 1.3 $
43  */

44 public class MetaBeanProperty extends MetaProperty {
45
46     private MetaMethod getter;
47     private MetaMethod setter;
48
49     public MetaBeanProperty(String JavaDoc name, Class JavaDoc type, MetaMethod getter, MetaMethod setter) {
50         super(name, type);
51         this.getter = getter;
52         this.setter = setter;
53     }
54
55     /**
56      * @return the property of the given object
57      * @throws Exception if the property could not be evaluated
58      */

59     public Object JavaDoc getProperty(Object JavaDoc object) throws Exception JavaDoc {
60         if (getter == null) {
61             //@todo we probably need a WriteOnlyException class
62
throw new GroovyRuntimeException("Cannot read write-only property: " + name);
63         }
64         return getter.invoke(object, MetaClass.EMPTY_ARRAY);
65     }
66
67     /**
68      * Sets the property on the given object to the new value
69      *
70      * @param object on which to set the property
71      * @param newValue the new value of the property
72      * @throws Exception if the property could not be set
73      */

74     public void setProperty(Object JavaDoc object, Object JavaDoc newValue) {
75         if(setter == null) {
76             throw new GroovyRuntimeException("Cannot set read-only property: " + name);
77         }
78
79         try {
80             // we'll convert a GString to String if needed
81
if(getType() == String JavaDoc.class && !(newValue instanceof String JavaDoc))
82                 newValue = newValue.toString();
83
84             // Set property for primitive types
85
if (newValue instanceof java.math.BigDecimal JavaDoc) {
86                 if (getType() == Double JavaDoc.class)
87                     newValue = new Double JavaDoc(((java.math.BigDecimal JavaDoc) newValue).doubleValue());
88                 else if (getType() == Float JavaDoc.class)
89                     newValue = new Float JavaDoc(((java.math.BigDecimal JavaDoc) newValue).floatValue());
90                 else if (getType() == Long JavaDoc.class)
91                     newValue = new Long JavaDoc(((java.math.BigDecimal JavaDoc) newValue).longValue());
92                 else if (getType() == Integer JavaDoc.class)
93                     newValue = new Integer JavaDoc(((java.math.BigDecimal JavaDoc) newValue).intValue());
94                 else if (getType() == Short JavaDoc.class)
95                     newValue = new Short JavaDoc((short) ((java.math.BigDecimal JavaDoc) newValue).intValue());
96                 else if (getType() == Byte JavaDoc.class)
97                     newValue = new Byte JavaDoc((byte) ((java.math.BigDecimal JavaDoc) newValue).intValue());
98                 else if (getType() == Character JavaDoc.class)
99                     newValue = new Character JavaDoc((char) ((java.math.BigDecimal JavaDoc) newValue).intValue());
100             }
101             else if (newValue instanceof java.math.BigInteger JavaDoc) {
102                 if (getType() == Long JavaDoc.class)
103                     newValue = new Long JavaDoc(((java.math.BigInteger JavaDoc) newValue).longValue());
104                 else if (getType() == Integer JavaDoc.class)
105                     newValue = new Integer JavaDoc(((java.math.BigInteger JavaDoc) newValue).intValue());
106                 else if (getType() == Short JavaDoc.class)
107                     newValue = new Short JavaDoc((short) ((java.math.BigInteger JavaDoc) newValue).intValue());
108                 else if (getType() == Byte JavaDoc.class)
109                     newValue = new Byte JavaDoc((byte) ((java.math.BigInteger JavaDoc) newValue).intValue());
110                 else if (getType() == Character JavaDoc.class)
111                     newValue = new Character JavaDoc((char) ((java.math.BigInteger JavaDoc) newValue).intValue());
112             }
113             else if (newValue instanceof java.lang.Long JavaDoc) {
114                 if (getType() == Integer JavaDoc.class)
115                     newValue = new Integer JavaDoc(((Long JavaDoc) newValue).intValue());
116                 else if (getType() == Short JavaDoc.class)
117                     newValue = new Short JavaDoc(((Long JavaDoc) newValue).shortValue());
118                 else if (getType() == Byte JavaDoc.class)
119                     newValue = new Byte JavaDoc(((Long JavaDoc) newValue).byteValue());
120                 else if (getType() == Character JavaDoc.class)
121                     newValue = new Character JavaDoc((char) ((Long JavaDoc) newValue).intValue());
122             }
123             else if (newValue instanceof java.lang.Integer JavaDoc) {
124                 if (getType() == Short JavaDoc.class)
125                     newValue = new Short JavaDoc(((Integer JavaDoc) newValue).shortValue());
126                 else if (getType() == Byte JavaDoc.class)
127                     newValue = new Byte JavaDoc(((Integer JavaDoc) newValue).byteValue());
128                 else if (getType() == Character JavaDoc.class)
129                     newValue = new Character JavaDoc((char) ((Integer JavaDoc) newValue).intValue());
130             }
131
132             setter.invoke(object, new Object JavaDoc[] { newValue });
133         }
134         catch(Exception JavaDoc e) {
135             throw new GroovyRuntimeException("Cannot set property: " + name +
136                 " reason: " + e.getMessage(), e);
137         }
138     }
139
140     public MetaMethod getGetter() {
141         return getter;
142     }
143
144     public MetaMethod getSetter() {
145         return setter;
146     }
147     
148     /**
149      * this is for MetaClass to patch up the object later when looking for get*() methods
150      */

151     void setGetter(MetaMethod getter) {
152         this.getter = getter;
153     }
154     
155     /**
156      * this is for MetaClass to patch up the object later when looking for set*() methods
157      */

158     void setSetter(MetaMethod setter) {
159         this.setter = setter;
160     }
161 }
162
Popular Tags