Package groovy.lang
Interface Writable
- All Known Implementing Classes:
Attribute
,Attributes
,BaseTemplate
,ConfigObject
,FilteredAttributes
,FilteredNodeChildren
,GPathResult
,GString
,GStringImpl
,JsonBuilder
,NoChildren
,Node
,NodeChild
,NodeChildren
,NodeParents
,ReplacementNode
,TomlBuilder
,WritableFile
,WritablePath
,YamlBuilder
public interface Writable
Represents an object which is capable of writing itself to a text stream
in a more efficient format than just creating a toString() representation
of itself. This mechanism is particularly useful for templates and such like.
It is worth noting that writable implementations often override their toString() implementation as well to allow rendering the same result directly to a String; however this is not required.
-
Method Summary
-
Method Details
-
writeTo
Writes this object to the given writer.This is used to defer content creation until the point when it is streamed to the output destination. Oftentimes, content will be defined but not necessarily created (as it may be the case with a Closure definition.) In that case, the output is then 'deferred' to the point when it is serialized to the writer. This class may be used whenever an object should be responsible for creating its own textual representation, but creating the entire output as a single String would be inefficient (such as outputting a multi-gigabyte XML document.)
- Parameters:
out
- the Writer to which this Writable should output its data.- Returns:
- the Writer that was passed
- Throws:
IOException
- if an error occurred while outputting data to the writer
-