3

This morning I had reason to try using multiple Converters on an inputText component and realized that this doesn't work.

Does anyone who why JSF only allows a single Converter per ValueHolder? It seems that using a series of Converters would be elegant in several situations.

Dave Maple
  • 8,102
  • 4
  • 45
  • 64
  • 1
    Actually, I see the issue -- I was thinking of a chain of converters where values were manipulated but not Type converted. If converter1 changes the type then converter2 isn't dealing with a String any longer and thus chaining wouldn't work. – Dave Maple Jul 12 '11 at 16:35

1 Answers1

11

In JSF, the Converter interface is designed with the following sole purpose:

Converter is an interface describing a Java class that can perform Object-to-String and String-to-Object conversions between model data objects and a String representation of those objects that is suitable for rendering.

...

getAsObject Convert the specified string value, which is associated with the specified UIComponent, into a model data object that is appropriate for being stored during the Apply Request Values phase of the request processing lifecycle.

getAsString Convert the specified model object value, which is associated with the specified UIComponent, into a String that is suitable for being included in the response generated during the Render Response phase of the request processing lifeycle.

Neither the javadoc nor the JSF spec tells about the possibility to chain converters.

Your best bet is to solve this problem at the implementation level. If you want to extend an existing converter, then you should just do so and then call super methods whenever appropriate. E.g.

public class SomeExtendedConverter extends SomeBasicConverter {

    @Override
    public Object getAsObject(FacesContext context, UIComponent component, String value) {
        Object basicConvertedValue = super.getAsObject(context, component, value);

        // ... manipulate more ...

        return extendedConvertedValue;
    }

    // ...
}
BalusC
  • 1,082,665
  • 372
  • 3,610
  • 3,555