/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.commons.cli; import java.io.File; import java.net.MalformedURLException; import java.net.URL; import java.util.Date; /** * This is a temporary implementation. TypeHandler will handle the * pluggableness of OptionTypes and it will direct all of these types * of conversion functionalities to ConvertUtils component in Commons * already. BeanUtils I think. * * @version $Id: TypeHandler.java 1677452 2015-05-03 17:10:00Z ggregory $ */ public class TypeHandler { /** * Returns the <code>Object</code> of type <code>obj</code> * with the value of <code>str</code>. * * @param str the command line value * @param obj the type of argument * @return The instance of <code>obj</code> initialised with * the value of <code>str</code>. * @throws ParseException if the value creation for the given object type failed */ public static Object createValue(String str, Object obj) throws ParseException { return createValue(str, (Class<?>) obj); } /** * Returns the <code>Object</code> of type <code>clazz</code> * with the value of <code>str</code>. * * @param str the command line value * @param clazz the type of argument * @return The instance of <code>clazz</code> initialised with * the value of <code>str</code>. * @throws ParseException if the value creation for the given class failed */ public static Object createValue(String str, Class<?> clazz) throws ParseException { if (PatternOptionBuilder.STRING_VALUE == clazz) { return str; } else if (PatternOptionBuilder.OBJECT_VALUE == clazz) { return createObject(str); } else if (PatternOptionBuilder.NUMBER_VALUE == clazz) { return createNumber(str); } else if (PatternOptionBuilder.DATE_VALUE == clazz) { return createDate(str); } else if (PatternOptionBuilder.CLASS_VALUE == clazz) { return createClass(str); } else if (PatternOptionBuilder.FILE_VALUE == clazz) { return createFile(str); } else if (PatternOptionBuilder.EXISTING_FILE_VALUE == clazz) { return createFile(str); } else if (PatternOptionBuilder.FILES_VALUE == clazz) { return createFiles(str); } else if (PatternOptionBuilder.URL_VALUE == clazz) { return createURL(str); } else { return null; } } /** * Create an Object from the classname and empty constructor. * * @param classname the argument value * @return the initialised object * @throws ParseException if the class could not be found or the object could not be created */ public static Object createObject(String classname) throws ParseException { Class<?> cl; try { cl = Class.forName(classname); } catch (ClassNotFoundException cnfe) { throw new ParseException("Unable to find the class: " + classname); } try { return cl.newInstance(); } catch (Exception e) { throw new ParseException(e.getClass().getName() + "; Unable to create an instance of: " + classname); } } /** * Create a number from a String. If a . is present, it creates a * Double, otherwise a Long. * * @param str the value * @return the number represented by <code>str</code> * @throws ParseException if <code>str</code> is not a number */ public static Number createNumber(String str) throws ParseException { try { if (str.indexOf('.') != -1) { return Double.valueOf(str); } return Long.valueOf(str); } catch (NumberFormatException e) { throw new ParseException(e.getMessage()); } } /** * Returns the class whose name is <code>classname</code>. * * @param classname the class name * @return The class if it is found * @throws ParseException if the class could not be found */ public static Class<?> createClass(String classname) throws ParseException { try { return Class.forName(classname); } catch (ClassNotFoundException e) { throw new ParseException("Unable to find the class: " + classname); } } /** * Returns the date represented by <code>str</code>. * <p> * This method is not yet implemented and always throws an * {@link UnsupportedOperationException}. * * @param str the date string * @return The date if <code>str</code> is a valid date string, * otherwise return null. * @throws UnsupportedOperationException always */ public static Date createDate(String str) { throw new UnsupportedOperationException("Not yet implemented"); } /** * Returns the URL represented by <code>str</code>. * * @param str the URL string * @return The URL in <code>str</code> is well-formed * @throws ParseException if the URL in <code>str</code> is not well-formed */ public static URL createURL(String str) throws ParseException { try { return new URL(str); } catch (MalformedURLException e) { throw new ParseException("Unable to parse the URL: " + str); } } /** * Returns the File represented by <code>str</code>. * * @param str the File location * @return The file represented by <code>str</code>. */ public static File createFile(String str) { return new File(str); } /** * Returns the File[] represented by <code>str</code>. * <p> * This method is not yet implemented and always throws an * {@link UnsupportedOperationException}. * * @param str the paths to the files * @return The File[] represented by <code>str</code>. * @throws UnsupportedOperationException always */ public static File[] createFiles(String str) { // to implement/port: // return FileW.findFiles(str); throw new UnsupportedOperationException("Not yet implemented"); } }