/*
 * Copyright 2002-2018 the original author or authors.
 *
 * Licensed 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
 *
 *      https://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.springframework.expression.spel.ast;

import java.util.List;
import java.util.StringJoiner;

import org.springframework.core.convert.TypeDescriptor;
import org.springframework.lang.Nullable;
import org.springframework.util.ClassUtils;

Utility methods (formatters etc) used during parsing and evaluation.
Author:Andy Clement
/** * Utility methods (formatters etc) used during parsing and evaluation. * * @author Andy Clement */
abstract class FormatHelper {
Produce a readable representation for a given method name with specified arguments.
Params:
  • name – the name of the method
  • argumentTypes – the types of the arguments to the method
Returns:a nicely formatted representation, e.g. foo(String,int)
/** * Produce a readable representation for a given method name with specified arguments. * @param name the name of the method * @param argumentTypes the types of the arguments to the method * @return a nicely formatted representation, e.g. {@code foo(String,int)} */
public static String formatMethodForMessage(String name, List<TypeDescriptor> argumentTypes) { StringJoiner sj = new StringJoiner(",", "(", ")"); for (TypeDescriptor typeDescriptor : argumentTypes) { if (typeDescriptor != null) { sj.add(formatClassNameForMessage(typeDescriptor.getType())); } else { sj.add(formatClassNameForMessage(null)); } } return name + sj.toString(); }
Determine a readable name for a given Class object.

A String array will have the formatted name "java.lang.String[]".

Params:
  • clazz – the Class whose name is to be formatted
See Also:
Returns:a formatted String suitable for message inclusion
/** * Determine a readable name for a given Class object. * <p>A String array will have the formatted name "java.lang.String[]". * @param clazz the Class whose name is to be formatted * @return a formatted String suitable for message inclusion * @see ClassUtils#getQualifiedName(Class) */
public static String formatClassNameForMessage(@Nullable Class<?> clazz) { return (clazz != null ? ClassUtils.getQualifiedName(clazz) : "null"); } }