1 /* Licensed to the Apache Software Foundation (ASF) under one or more
2 * contributor license agreements. See the NOTICE file distributed with
3 * this work for additional information regarding copyright ownership.
4 * The ASF licenses this file to You under the Apache License, Version 2.0
5 * (the "License"); you may not use this file except in compliance with
6 * the License. You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
19 import java.io.Serializable;
22 * An {@code IllegalFormatConversionException} will be thrown when the parameter
23 * is incompatible with the corresponding format specifier.
25 * @see java.lang.RuntimeException
29 public class IllegalFormatConversionException extends IllegalFormatException
30 implements Serializable {
31 private static final long serialVersionUID = 17000126L;
35 private final Class<?> arg;
38 * Constructs a new {@code IllegalFormatConversionException} with the class
39 * of the mismatched conversion and corresponding parameter.
42 * the class of the mismatched conversion.
44 * the corresponding parameter.
46 public IllegalFormatConversionException(char c, Class<?> arg) {
49 throw new NullPointerException();
55 * Returns the class of the mismatched parameter.
57 * @return the class of the mismatched parameter.
59 public Class<?> getArgumentClass() {
64 * Returns the incompatible conversion.
66 * @return the incompatible conversion.
68 public char getConversion() {
73 public String getMessage() {
74 return "%" + c + " can't format " + arg.getName() + " arguments";