Class PropertiesConfiguration.PropertiesWriter
java.lang.Object
java.io.Writer
java.io.FilterWriter
org.apache.commons.configuration2.PropertiesConfiguration.PropertiesWriter
- All Implemented Interfaces:
- Closeable,- Flushable,- Appendable,- AutoCloseable
- Direct Known Subclasses:
- PropertiesConfiguration.JupPropertiesWriter
- Enclosing class:
- PropertiesConfiguration
This class is used to write properties lines. The most important method is
 
writeProperty(String, Object, boolean), which is called during a save operation for each property found in
 the configuration.- 
Field SummaryFields inherited from class java.io.FilterWriterout
- 
Constructor SummaryConstructorsConstructorDescriptionPropertiesWriter(Writer writer, ListDelimiterHandler delHandler) Creates a new instance ofPropertiesWriter.PropertiesWriter(Writer writer, ListDelimiterHandler delHandler, ValueTransformer valueTransformer) Creates a new instance ofPropertiesWriter.
- 
Method SummaryModifier and TypeMethodDescriptionprotected StringEscapes the key of a property before it gets written to file.protected StringfetchSeparator(String key, Object value) Returns the separator to be used for the given property.Gets the current property separator.Gets the delimiter handler for properties with multiple values.Gets the global property separator.Gets the line separator.voidsetCurrentSeparator(String currentSeparator) Sets the current property separator.voidsetGlobalSeparator(String globalSeparator) Sets the global property separator.voidsetLineSeparator(String lineSeparator) Sets the line separator.voidwriteComment(String comment) Write a comment.voidHelper method for writing a line with the platform specific line ending.voidwriteProperty(String key, Object value) Write a property.voidwriteProperty(String key, Object value, boolean forceSingleLine) Writes the given property and its value.voidwriteProperty(String key, List<?> values) Write a property.
- 
Constructor Details- 
PropertiesWriterCreates a new instance ofPropertiesWriter.- Parameters:
- writer- a Writer object providing the underlying stream
- delHandler- the delimiter handler for dealing with properties with multiple values
 
- 
PropertiesWriterpublic PropertiesWriter(Writer writer, ListDelimiterHandler delHandler, ValueTransformer valueTransformer) Creates a new instance ofPropertiesWriter.- Parameters:
- writer- a Writer object providing the underlying stream
- delHandler- the delimiter handler for dealing with properties with multiple values
- valueTransformer- the value transformer used to escape property values
 
 
- 
- 
Method Details- 
escapeKeyEscapes the key of a property before it gets written to file. This method is called on saving a configuration for each property key. It ensures that separator characters contained in the key are escaped.- Parameters:
- key- the key
- Returns:
- the escaped key
- Since:
- 2.0
 
- 
fetchSeparatorReturns the separator to be used for the given property. This method is called bywriteProperty(). The string returned here is used as separator between the property key and its value. Per default the method checks whether a global separator is set. If this is the case, it is returned. Otherwise the separator returned bygetCurrentSeparator()is used, which was set by the associated layout object. Derived classes may implement a different strategy for defining the separator.- Parameters:
- key- the property key
- value- the value
- Returns:
- the separator to be used
- Since:
- 1.7
 
- 
getCurrentSeparatorGets the current property separator.- Returns:
- the current property separator
- Since:
- 1.7
 
- 
getDelimiterHandlerGets the delimiter handler for properties with multiple values. This object is used to escape property values so that they can be read in correctly the next time they are loaded.- Returns:
- the delimiter handler for properties with multiple values
- Since:
- 2.0
 
- 
getGlobalSeparatorGets the global property separator.- Returns:
- the global property separator
- Since:
- 1.7
 
- 
getLineSeparatorGets the line separator.- Returns:
- the line separator
- Since:
- 1.7
 
- 
setCurrentSeparatorSets the current property separator. This separator is used when writing the next property.- Parameters:
- currentSeparator- the current property separator
- Since:
- 1.7
 
- 
setGlobalSeparatorSets the global property separator. This separator corresponds to theglobalSeparatorproperty ofPropertiesConfigurationLayout. It defines the separator to be used for all properties. If it is undefined, the current separator is used.- Parameters:
- globalSeparator- the global property separator
- Since:
- 1.7
 
- 
setLineSeparatorSets the line separator. Each line written by this writer is terminated with this separator. If not set, the platform-specific line separator is used.- Parameters:
- lineSeparator- the line separator to be used
- Since:
- 1.7
 
- 
writeCommentWrite a comment.- Parameters:
- comment- the comment to write
- Throws:
- IOException- if an I/O error occurs.
 
- 
writelnHelper method for writing a line with the platform specific line ending.- Parameters:
- s- the content of the line (may be null)
- Throws:
- IOException- if an error occurs
- Since:
- 1.3
 
- 
writePropertyWrite a property.- Parameters:
- key- The key of the property
- values- The array of values of the property
- Throws:
- IOException- if an I/O error occurs.
 
- 
writePropertyWrite a property.- Parameters:
- key- the key of the property
- value- the value of the property
- Throws:
- IOException- if an I/O error occurs.
 
- 
writePropertyWrites the given property and its value. If the value happens to be a list, theforceSingleLineflag is evaluated. If it is set, all values are written on a single line using the list delimiter as separator.- Parameters:
- key- the property key
- value- the property value
- forceSingleLine- the "force single line" flag
- Throws:
- IOException- if an error occurs
- Since:
- 1.3
 
 
-