Class MessageSourceSupport
- Direct Known Subclasses:
- AbstractMessageSource,- DelegatingMessageSource
MessageFormat handling but not implementing concrete
 methods defined in the MessageSource.
 AbstractMessageSource derives from this class, providing concrete
 getMessage implementations that delegate to a central template
 method for message code resolution.
- Since:
- 2.5.5
- Author:
- Juergen Hoeller
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected MessageFormatcreateMessageFormat(String msg, Locale locale) Create aMessageFormatfor the given message and Locale.protected StringformatMessage(String msg, Object[] args, Locale locale) Format the given message String, using cached MessageFormats.protected booleanReturn whether to always apply theMessageFormatrules, parsing even messages without arguments.protected StringrenderDefaultMessage(String defaultMessage, Object[] args, Locale locale) Render the given default message String.protected Object[]resolveArguments(Object[] args, Locale locale) Template method for resolving argument objects.voidsetAlwaysUseMessageFormat(boolean alwaysUseMessageFormat) Set whether to always apply theMessageFormatrules, parsing even messages without arguments.
- 
Field Details- 
loggerLogger available to subclasses.
 
- 
- 
Constructor Details- 
MessageSourceSupportpublic MessageSourceSupport()
 
- 
- 
Method Details- 
setAlwaysUseMessageFormatpublic void setAlwaysUseMessageFormat(boolean alwaysUseMessageFormat) Set whether to always apply theMessageFormatrules, parsing even messages without arguments.Default is false: Messages without arguments are by default returned as-is, without parsing them throughMessageFormat. Set this totrueto enforceMessageFormatfor all messages, expecting all message texts to be written withMessageFormatescaping.For example, MessageFormatexpects a single quote to be escaped as two adjacent single quotes ("''"). If your message texts are all written with such escaping, even when not defining argument placeholders, you need to set this flag totrue. Otherwise, only message texts with actual arguments are supposed to be written withMessageFormatescaping.- See Also:
 
- 
isAlwaysUseMessageFormatprotected boolean isAlwaysUseMessageFormat()Return whether to always apply theMessageFormatrules, parsing even messages without arguments.
- 
renderDefaultMessageprotected String renderDefaultMessage(String defaultMessage, @Nullable Object[] args, @Nullable Locale locale) Render the given default message String. The default message is passed in as specified by the caller and can be rendered into a fully formatted default message shown to the user.The default implementation passes the String to formatMessage, resolving any argument placeholders found in them. Subclasses may override this method to plug in custom processing of default messages.- Parameters:
- defaultMessage- the passed-in default message String
- args- array of arguments that will be filled in for params within the message, or- nullif none.
- locale- the Locale used for formatting
- Returns:
- the rendered default message (with resolved arguments)
- See Also:
 
- 
formatMessageFormat the given message String, using cached MessageFormats. By default invoked for passed-in default messages, to resolve any argument placeholders found in them.- Parameters:
- msg- the message to format
- args- array of arguments that will be filled in for params within the message, or- nullif none
- locale- the Locale used for formatting
- Returns:
- the formatted message (with resolved arguments)
 
- 
createMessageFormatCreate aMessageFormatfor the given message and Locale.- Parameters:
- msg- the message to create a- MessageFormatfor
- locale- the Locale to create a- MessageFormatfor
- Returns:
- the MessageFormatinstance
 
- 
resolveArgumentsTemplate method for resolving argument objects.The default implementation simply returns the given argument array as-is. Can be overridden in subclasses in order to resolve special argument types. - Parameters:
- args- the original argument array
- locale- the Locale to resolve against
- Returns:
- the resolved argument array
 
 
-