/*
 * 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.format;

import java.lang.annotation.Annotation;

import org.springframework.core.convert.converter.ConverterRegistry;

A registry of field formatting logic.
Author:Keith Donald, Juergen Hoeller
Since:3.0
/** * A registry of field formatting logic. * * @author Keith Donald * @author Juergen Hoeller * @since 3.0 */
public interface FormatterRegistry extends ConverterRegistry {
Adds a Printer to print fields of a specific type. The field type is implied by the parameterized Printer instance.
Params:
  • printer – the printer to add
See Also:
Since:5.2
/** * Adds a Printer to print fields of a specific type. * The field type is implied by the parameterized Printer instance. * @param printer the printer to add * @since 5.2 * @see #addFormatter(Formatter) */
void addPrinter(Printer<?> printer);
Adds a Parser to parse fields of a specific type. The field type is implied by the parameterized Parser instance.
Params:
  • parser – the parser to add
See Also:
Since:5.2
/** * Adds a Parser to parse fields of a specific type. * The field type is implied by the parameterized Parser instance. * @param parser the parser to add * @since 5.2 * @see #addFormatter(Formatter) */
void addParser(Parser<?> parser);
Adds a Formatter to format fields of a specific type. The field type is implied by the parameterized Formatter instance.
Params:
  • formatter – the formatter to add
See Also:
Since:3.1
/** * Adds a Formatter to format fields of a specific type. * The field type is implied by the parameterized Formatter instance. * @param formatter the formatter to add * @since 3.1 * @see #addFormatterForFieldType(Class, Formatter) */
void addFormatter(Formatter<?> formatter);
Adds a Formatter to format fields of the given type.

On print, if the Formatter's type T is declared and fieldType is not assignable to T, a coercion to T will be attempted before delegating to formatter to print a field value. On parse, if the parsed object returned by formatter is not assignable to the runtime field type, a coercion to the field type will be attempted before returning the parsed field value.

Params:
  • fieldType – the field type to format
  • formatter – the formatter to add
/** * Adds a Formatter to format fields of the given type. * <p>On print, if the Formatter's type T is declared and {@code fieldType} is not assignable to T, * a coercion to T will be attempted before delegating to {@code formatter} to print a field value. * On parse, if the parsed object returned by {@code formatter} is not assignable to the runtime field type, * a coercion to the field type will be attempted before returning the parsed field value. * @param fieldType the field type to format * @param formatter the formatter to add */
void addFormatterForFieldType(Class<?> fieldType, Formatter<?> formatter);
Adds a Printer/Parser pair to format fields of a specific type. The formatter will delegate to the specified printer for printing and the specified parser for parsing.

On print, if the Printer's type T is declared and fieldType is not assignable to T, a coercion to T will be attempted before delegating to printer to print a field value. On parse, if the object returned by the Parser is not assignable to the runtime field type, a coercion to the field type will be attempted before returning the parsed field value.

Params:
  • fieldType – the field type to format
  • printer – the printing part of the formatter
  • parser – the parsing part of the formatter
/** * Adds a Printer/Parser pair to format fields of a specific type. * The formatter will delegate to the specified {@code printer} for printing * and the specified {@code parser} for parsing. * <p>On print, if the Printer's type T is declared and {@code fieldType} is not assignable to T, * a coercion to T will be attempted before delegating to {@code printer} to print a field value. * On parse, if the object returned by the Parser is not assignable to the runtime field type, * a coercion to the field type will be attempted before returning the parsed field value. * @param fieldType the field type to format * @param printer the printing part of the formatter * @param parser the parsing part of the formatter */
void addFormatterForFieldType(Class<?> fieldType, Printer<?> printer, Parser<?> parser);
Adds a Formatter to format fields annotated with a specific format annotation.
Params:
  • annotationFormatterFactory – the annotation formatter factory to add
/** * Adds a Formatter to format fields annotated with a specific format annotation. * @param annotationFormatterFactory the annotation formatter factory to add */
void addFormatterForFieldAnnotation(AnnotationFormatterFactory<? extends Annotation> annotationFormatterFactory); }