Class AbstractListDelimiterHandler
java.lang.Object
org.apache.commons.configuration2.convert.AbstractListDelimiterHandler
- All Implemented Interfaces:
- ListDelimiterHandler
- Direct Known Subclasses:
- DefaultListDelimiterHandler,- DisabledListDelimiterHandler,- LegacyListDelimiterHandler
 An abstract base class for concrete ListDelimiterHandler implementations.
 
This base class provides a fully functional implementation for parsing a value object which can deal with different cases like collections, arrays, iterators, etc. This logic is typically needed by every concrete subclass. Other methods are partly implemented handling special corner cases like null values; concrete subclasses do not have do implement the corresponding checks.
- Since:
- 2.0
- 
Field SummaryFields inherited from interface org.apache.commons.configuration2.convert.ListDelimiterHandlerNOOP_TRANSFORMER
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionescape(Object value, ValueTransformer transformer) Escapes the specified single value object.protected abstract StringEscapes the specified string.Iterable<?> Parses the specified value for list delimiters and splits it if necessary.Splits the specified string at the list delimiter and returns a collection with all extracted components.protected abstract Collection<String> splitString(String s, boolean trim) Actually splits the passed in string which is guaranteed to be not null.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.commons.configuration2.convert.ListDelimiterHandlerescapeList, flatten
- 
Constructor Details- 
AbstractListDelimiterHandlerpublic AbstractListDelimiterHandler()
 
- 
- 
Method Details- 
escapeEscapes the specified single value object. This method is called for properties containing only a single value. So this method can rely on the fact that the passed in object is not a list. An implementation has to check whether the value contains list delimiter characters and - if so - escape them accordingly. This implementation checks whether the object to be escaped is a string. If yes, it delegates toescapeString(String), otherwise no escaping is performed. Eventually, the passed in transformer is invoked so that additional encoding can be performed.- Specified by:
- escapein interface- ListDelimiterHandler
- Parameters:
- value- the value to be escaped
- transformer- a- ValueTransformerfor an additional encoding (must not be null)
- Returns:
- the escaped value
 
- 
escapeStringEscapes the specified string. This method is called byescape()if the passed in object is a string. Concrete subclasses have to implement their specific escaping logic here, so that the list delimiters they support are properly escaped.- Parameters:
- s- the string to be escaped (not null)
- Returns:
- the escaped string
 
- 
parseParses the specified value for list delimiters and splits it if necessary. The passed in object can be either a single value or a complex one, for example a collection, an array, or anIterable. It is the responsibility of this method to return anIterablewhich contains all extracted values. Depending on the type of the passed in object the following things happen:- Strings are checked for delimiter characters and split if necessary. This is done by calling the split()method.
- For objects implementing the Iterableinterface, the correspondingIteratoris obtained, and contained elements are added to the resulting iteration.
- Arrays are treated as Iterableobjects.
- All other types are directly inserted.
- Recursive combinations are supported, for example a collection containing an array that contains strings: The resulting collection will only contain primitive objects.
 - Specified by:
- parsein interface- ListDelimiterHandler
- Parameters:
- value- the value to be parsed
- Returns:
- an Iterableallowing access to all extracted values
 
- Strings are checked for delimiter characters and split if necessary. This is done by calling the 
- 
splitSplits the specified string at the list delimiter and returns a collection with all extracted components. A concrete implementation also has to deal with escape characters which might mask a list delimiter character at certain positions. The booleantrimflag determines whether each extracted component should be trimmed. This typically makes sense as the list delimiter may be surrounded by whitespace. However, there may be specific use cases in which automatic trimming is not desired. This implementation handles the case that the passed in string is null. In this case, an empty collection is returned. Otherwise, this method delegates tosplitString(String, boolean).- Specified by:
- splitin interface- ListDelimiterHandler
- Parameters:
- s- the string to be split
- trim- a flag whether each component of the string is to be trimmed
- Returns:
- a collection with all components extracted from the string
 
- 
splitStringActually splits the passed in string which is guaranteed to be not null. This method is called by the base implementation of thesplit()method. Here the actual splitting logic has to be implemented.- Parameters:
- s- the string to be split (not null)
- trim- a flag whether the single components have to be trimmed
- Returns:
- a collection with the extracted components of the passed in string
 
 
-