View Javadoc

1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one or more
3    * contributor license agreements.  See the NOTICE file distributed with
4    * this work for additional information regarding copyright ownership.
5    * The ASF licenses this file to You under the Apache License, Version 2.0
6    * (the "License"); you may not use this file except in compliance with
7    * the License.  You may obtain a copy of the License at
8    *
9    *      http://www.apache.org/licenses/LICENSE-2.0
10   *
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS,
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14   * See the License for the specific language governing permissions and
15   * limitations under the License.
16   */
17  
18  
19  package org.apache.commons.beanutils;
20  
21  /**
22   * <p>Utility methods for converting String scalar values to objects of the
23   * specified Class, String arrays to arrays of the specified Class.</p>
24   *
25   * <p>For more details, see <code>ConvertUtilsBean</code> which provides the
26   * implementations for these methods.</p>
27   *
28   * @author Craig R. McClanahan
29   * @author Ralph Schaer
30   * @author Chris Audley
31   * @version $Revision: 556229 $ $Date: 2007-07-14 02:11:19 -0400 (Sat, 14 Jul 2007) $
32   * @see ConvertUtilsBean
33   */
34  
35  public class ConvertUtils {
36  
37  
38      // ------------------------------------------------------ Static Properties
39  
40      /**
41       * Gets the default value for Boolean conversions.
42       * @return The default Boolean value
43       * @deprecated Register replacement converters for Boolean.TYPE and
44       *  Boolean.class instead
45       */
46      public static boolean getDefaultBoolean() {
47          return (ConvertUtilsBean.getInstance().getDefaultBoolean());
48      }
49  
50      /**
51       * Sets the default value for Boolean conversions.
52       * @param newDefaultBoolean The default Boolean value
53       * @deprecated Register replacement converters for Boolean.TYPE and
54       *  Boolean.class instead
55       */
56      public static void setDefaultBoolean(boolean newDefaultBoolean) {
57          ConvertUtilsBean.getInstance().setDefaultBoolean(newDefaultBoolean);
58      }
59  
60  
61      /**
62       * Gets the default value for Byte conversions.
63       * @return The default Byte value
64       * @deprecated Register replacement converters for Byte.TYPE and
65       *  Byte.class instead
66       */
67      public static byte getDefaultByte() {
68          return ConvertUtilsBean.getInstance().getDefaultByte();
69      }
70  
71      /**
72       * Sets the default value for Byte conversions.
73       * @param newDefaultByte The default Byte value
74       * @deprecated Register replacement converters for Byte.TYPE and
75       *  Byte.class instead
76       */
77      public static void setDefaultByte(byte newDefaultByte) {
78          ConvertUtilsBean.getInstance().setDefaultByte(newDefaultByte);
79      }
80  
81  
82      /**
83       * Gets the default value for Character conversions.
84       * @return The default Character value
85       * @deprecated Register replacement converters for Character.TYPE and
86       *  Character.class instead
87       */
88      public static char getDefaultCharacter() {
89          return ConvertUtilsBean.getInstance().getDefaultCharacter();
90      }
91  
92      /**
93       * Sets the default value for Character conversions.
94       * @param newDefaultCharacter The default Character value
95       * @deprecated Register replacement converters for Character.TYPE and
96       *  Character.class instead
97       */
98      public static void setDefaultCharacter(char newDefaultCharacter) {
99          ConvertUtilsBean.getInstance().setDefaultCharacter(newDefaultCharacter);
100     }
101 
102 
103     /**
104      * Gets the default value for Double conversions.
105      * @return The default Double value
106      * @deprecated Register replacement converters for Double.TYPE and
107      *  Double.class instead
108      */
109     public static double getDefaultDouble() {
110         return ConvertUtilsBean.getInstance().getDefaultDouble();
111     }
112 
113     /**
114      * Sets the default value for Double conversions.
115      * @param newDefaultDouble The default Double value
116      * @deprecated Register replacement converters for Double.TYPE and
117      *  Double.class instead
118      */
119     public static void setDefaultDouble(double newDefaultDouble) {
120         ConvertUtilsBean.getInstance().setDefaultDouble(newDefaultDouble);
121     }
122 
123 
124     /**
125      * Get the default value for Float conversions.
126      * @return The default Float value
127      * @deprecated Register replacement converters for Float.TYPE and
128      *  Float.class instead
129      */
130     public static float getDefaultFloat() {
131         return ConvertUtilsBean.getInstance().getDefaultFloat();
132     }
133 
134     /**
135      * Sets the default value for Float conversions.
136      * @param newDefaultFloat The default Float value
137      * @deprecated Register replacement converters for Float.TYPE and
138      *  Float.class instead
139      */
140     public static void setDefaultFloat(float newDefaultFloat) {
141         ConvertUtilsBean.getInstance().setDefaultFloat(newDefaultFloat);
142     }
143 
144 
145     /**
146      * Gets the default value for Integer conversions.
147      * @return The default Integer value
148      * @deprecated Register replacement converters for Integer.TYPE and
149      *  Integer.class instead
150      */
151     public static int getDefaultInteger() {
152         return ConvertUtilsBean.getInstance().getDefaultInteger();
153     }
154 
155     /**
156      * Sets the default value for Integer conversions.
157      * @param newDefaultInteger The default Integer value
158      * @deprecated Register replacement converters for Integer.TYPE and
159      *  Integer.class instead
160      */
161     public static void setDefaultInteger(int newDefaultInteger) {
162         ConvertUtilsBean.getInstance().setDefaultInteger(newDefaultInteger);
163     }
164 
165 
166     /**
167      * Gets the default value for Long conversions.
168      * @return The default Long value
169      * @deprecated Register replacement converters for Long.TYPE and
170      *  Long.class instead
171      */
172     public static long getDefaultLong() {
173         return (ConvertUtilsBean.getInstance().getDefaultLong());
174     }
175 
176     /**
177      * Sets the default value for Long conversions.
178      * @param newDefaultLong The default Long value
179      * @deprecated Register replacement converters for Long.TYPE and
180      *  Long.class instead
181      */
182     public static void setDefaultLong(long newDefaultLong) {
183         ConvertUtilsBean.getInstance().setDefaultLong(newDefaultLong);
184     }
185 
186 
187     /**
188      * Gets the default value for Short conversions.
189      * @return The default Short value
190      * @deprecated Register replacement converters for Short.TYPE and
191      *  Short.class instead
192      */
193     public static short getDefaultShort() {
194         return ConvertUtilsBean.getInstance().getDefaultShort();
195     }
196 
197     /**
198      * Sets the default value for Short conversions.
199      * @param newDefaultShort The default Short value
200      * @deprecated Register replacement converters for Short.TYPE and
201      *  Short.class instead
202      */
203     public static void setDefaultShort(short newDefaultShort) {
204         ConvertUtilsBean.getInstance().setDefaultShort(newDefaultShort);
205     }
206 
207     // --------------------------------------------------------- Public Classes
208 
209 
210     /**
211      * <p>Convert the specified value into a String.</p>
212      *
213      * <p>For more details see <code>ConvertUtilsBean</code>.</p>
214      *
215      * @param value Value to be converted (may be null)
216      * @return The converted String value
217      *
218      * @see ConvertUtilsBean#convert(Object)
219      */
220     public static String convert(Object value) {
221 
222         return ConvertUtilsBean.getInstance().convert(value);
223 
224     }
225 
226 
227     /**
228      * <p>Convert the specified value to an object of the specified class (if
229      * possible).  Otherwise, return a String representation of the value.</p>
230      *
231      * <p>For more details see <code>ConvertUtilsBean</code>.</p>
232      *
233      * @param value Value to be converted (may be null)
234      * @param clazz Java class to be converted to
235      * @return The converted value
236      *
237      * @see ConvertUtilsBean#convert(String, Class)
238      */
239     public static Object convert(String value, Class clazz) {
240 
241         return ConvertUtilsBean.getInstance().convert(value, clazz);
242 
243     }
244 
245 
246     /**
247      * <p>Convert an array of specified values to an array of objects of the
248      * specified class (if possible).</p>
249      *
250      * <p>For more details see <code>ConvertUtilsBean</code>.</p>
251      *
252      * @param values Array of values to be converted
253      * @param clazz Java array or element class to be converted to
254      * @return The converted value
255      *
256      * @see ConvertUtilsBean#convert(String[], Class)
257      */
258     public static Object convert(String[] values, Class clazz) {
259 
260   return ConvertUtilsBean.getInstance().convert(values, clazz);
261 
262     }
263 
264     /**
265      * <p>Convert the value to an object of the specified class (if
266      * possible).</p>
267      *
268      * @param value Value to be converted (may be null)
269      * @param targetType Class of the value to be converted to
270      * @return The converted value
271      *
272      * @exception ConversionException if thrown by an underlying Converter
273      */
274     public static Object convert(Object value, Class targetType) {
275 
276         return ConvertUtilsBean.getInstance().convert(value, targetType);
277 
278     }
279 
280     /**
281      * <p>Remove all registered {@link Converter}s, and re-establish the
282      * standard Converters.</p>
283      *
284      * <p>For more details see <code>ConvertUtilsBean</code>.</p>
285      *
286      * @see ConvertUtilsBean#deregister()
287      */
288     public static void deregister() {
289 
290         ConvertUtilsBean.getInstance().deregister();
291 
292     }
293 
294 
295     /**
296      * <p>Remove any registered {@link Converter} for the specified destination
297      * <code>Class</code>.</p>
298      *
299      * <p>For more details see <code>ConvertUtilsBean</code>.</p>
300      *
301      * @param clazz Class for which to remove a registered Converter
302      * @see ConvertUtilsBean#deregister(Class)
303      */
304     public static void deregister(Class clazz) {
305 
306         ConvertUtilsBean.getInstance().deregister(clazz);
307 
308     }
309 
310 
311     /**
312      * <p>Look up and return any registered {@link Converter} for the specified
313      * destination class; if there is no registered Converter, return
314      * <code>null</code>.</p>
315      *
316      * <p>For more details see <code>ConvertUtilsBean</code>.</p>
317      *
318      * @param clazz Class for which to return a registered Converter
319      * @return The registered {@link Converter} or <code>null</code> if not found
320      * @see ConvertUtilsBean#lookup(Class)
321      */
322     public static Converter lookup(Class clazz) {
323 
324         return ConvertUtilsBean.getInstance().lookup(clazz);
325 
326     }
327 
328     /**
329      * Look up and return any registered {@link Converter} for the specified
330      * source and destination class; if there is no registered Converter,
331      * return <code>null</code>.
332      *
333      * @param sourceType Class of the value being converted
334      * @param targetType Class of the value to be converted to
335      * @return The registered {@link Converter} or <code>null</code> if not found
336      */
337     public static Converter lookup(Class sourceType, Class targetType) {
338 
339         return ConvertUtilsBean.getInstance().lookup(sourceType, targetType);
340 
341     }
342 
343     /**
344      * <p>Register a custom {@link Converter} for the specified destination
345      * <code>Class</code>, replacing any previously registered Converter.</p>
346      *
347      * <p>For more details see <code>ConvertUtilsBean</code>.</p>
348      *
349      * @param converter Converter to be registered
350      * @param clazz Destination class for conversions performed by this
351      *  Converter
352      * @see ConvertUtilsBean#register(Converter, Class)
353      */
354     public static void register(Converter converter, Class clazz) {
355 
356         ConvertUtilsBean.getInstance().register(converter, clazz);
357 
358     }
359 
360 
361 }