View Javadoc
1   /*
2    * Copyright (C) 2013 4th Line GmbH, Switzerland
3    *
4    * The contents of this file are subject to the terms of either the GNU
5    * Lesser General Public License Version 2 or later ("LGPL") or the
6    * Common Development and Distribution License Version 1 or later
7    * ("CDDL") (collectively, the "License"). You may not use this file
8    * except in compliance with the License. See LICENSE.txt for more
9    * information.
10   *
11   * This program is distributed in the hope that it will be useful,
12   * but WITHOUT ANY WARRANTY; without even the implied warranty of
13   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
14   */
15  
16  package org.fourthline.cling.model.types;
17  
18  /**
19   *
20   * @author Christian Bauer
21   */
22  public class ShortDatatype extends AbstractDatatype<Short> {
23  
24      @Override
25      public boolean isHandlingJavaType(Class type) {
26          return type == Short.TYPE || Short.class.isAssignableFrom(type);
27      }
28  
29      public Short valueOf(String s) throws InvalidValueException {
30          if (s.equals("")) return null;
31          try {
32              Short value = Short.parseShort(s.trim());
33              if (!isValid(value)) {
34                  throw new InvalidValueException("Not a valid short: " + s);
35              }
36              return value;
37          } catch (NumberFormatException ex) {
38              throw new InvalidValueException("Can't convert string to number: " + s, ex);
39          }
40      }
41  
42  }