Class WriterDelegator<W extends SymbolWriter<W,? extends ImportContainer>> 
- Type Parameters:
- W- The type of- SymbolWriterto create and manage.
- All Implemented Interfaces:
- SymbolDependencyContainer
Creates and manages SymbolWriters for files and namespaces based
 on Symbols created for a Shape.
 
Overview
WriterDelegator is designed to generate code in files
 returned by the Symbol.getDefinitionFile() method of a Symbol.
 If multiple Symbols are created that need to be defined in the same
 file, then the WriterDelegator ensures that the state of code
 generator associated with the file is persisted and only written when all
 shapes have been generated.
 
SymbolWriters are lazily created each time a new filename is
 requested. If a SymbolWriter is already associated with a filename,
 a newline (\n) is written to the file before providing access to the
 SymbolWriter. All of the files and SymbolWriters stored in the
 delegator are eventually written to the provided FileManifest when
 the flushWriters() method is called.
 
This class is not thread-safe.
Extending WriterDelegator
 Language-specific code generators that utilize Symbol and
 SymbolDependency should extend both
 WriterDelegator and SymbolWriter to implement
 language specific functionality. Extending these classes also makes it
 easier to create new instances of them because they will be easier to work
 with since generic types aren't needed in concrete implementations.
- 
Constructor SummaryConstructorsConstructorDescriptionWriterDelegator(FileManifest fileManifest, SymbolProvider symbolProvider, SymbolWriter.Factory<W> factory) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidWrites each pendingSymbolWriterto theFileManifest.Gets all of the dependencies that have been registered in writers created by theWriterDelegator.Returns an immutableMapof createdSymbolWriters.final voidsetAutomaticSeparator(String automaticSeparator) Sets the automatic separator that is written to aSymbolWritereach time the writer is reused.voidsetInterceptors(List<? extends CodeInterceptor<? extends CodeSection, W>> interceptors) Sets the list of code interceptors to registered with each newly created writer.final voiduseFileWriter(String filename, String namespace, Consumer<W> writerConsumer) Gets a previously created writer or creates a new one if needed.final voiduseFileWriter(String filename, Consumer<W> writerConsumer) Gets a previously createdSymbolWriteror creates a new one if needed.voiduseShapeWriter(Shape shape, Consumer<W> writerConsumer) 
- 
Constructor Details- 
WriterDelegatorpublic WriterDelegator(FileManifest fileManifest, SymbolProvider symbolProvider, SymbolWriter.Factory<W> factory) - Parameters:
- fileManifest- Where code is written when- flushWriters()is called.
- symbolProvider- Maps- Shapeto- Symbolto determine the "namespace" and file of a shape.
- factory- Factory used to create new- SymbolWriters.
 
 
- 
- 
Method Details- 
setInterceptorsSets the list of code interceptors to registered with each newly created writer.- Parameters:
- interceptors- Interceptors to register.
 
- 
getDependenciesGets all of the dependencies that have been registered in writers created by theWriterDelegator.This method essentially just aggregates the results of calling SymbolWriter.getDependencies()of each created writer into a single array.This method may be overridden as needed (for example, to add in some list of default dependencies or to inject other generative dependencies). - Specified by:
- getDependenciesin interface- SymbolDependencyContainer
- Returns:
- Returns all the dependencies used in each writer.
 
- 
flushWriterspublic void flushWriters()Writes each pendingSymbolWriterto theFileManifest.The toStringmethod is called on each writer to generate the code to write to the manifest.This method clears out the managed SymbolWriters, meaning a subsequent call togetWriters()will return an empty map.This method may be overridden as needed. 
- 
getWritersReturns an immutableMapof createdSymbolWriters.Each map key is the relative filename where the code will be written in the FileManifest, and each map value is the associatedSymbolWriterof typeT.- Returns:
- Returns the immutable map of files to writers.
 
- 
useFileWriterGets a previously createdSymbolWriteror creates a new one if needed.If a writer already exists, a newline is automatically appended to the writer (either a newline or whatever value was set on setAutomaticSeparator(java.lang.String)).- Parameters:
- filename- Name of the file to create.
- writerConsumer- Consumer that is expected to write to the- SymbolWriter.
 
- 
useFileWriterGets a previously created writer or creates a new one if needed.If a writer already exists, a newline is automatically appended to the writer (either a newline or whatever value was set on setAutomaticSeparator(java.lang.String)).- Parameters:
- filename- Name of the file to create.
- namespace- Namespace associated with the file (or an empty string).
- writerConsumer- Consumer that is expected to write to the- SymbolWriter.
 
- 
useShapeWriterGets or creates a writer for aShapeby converting theShapeto aSymbol.Any dependencies (i.e., SymbolDependency) required by theSymbolare automatically registered with the writer.Any imports required to declare the Symbolin code (i.e.,SymbolReference.ContextOption.DECLARE) are automatically registered with the writer.If a writer already exists, a newline is automatically appended to the writer (either a newline or whatever value was set on setAutomaticSeparator(java.lang.String)).This method may be overridden as needed. - Parameters:
- shape- Shape to create the writer for.
- writerConsumer- Consumer that is expected to write to the- SymbolWriter.
 
- 
setAutomaticSeparatorSets the automatic separator that is written to aSymbolWritereach time the writer is reused.The default line separator is a newline ("\n"), but some implementations may wish to use an alternative value (e.g., "\r\n") or to disable the newline separator altogether by proving an empty string. - Parameters:
- automaticSeparator- The non-null line separator to use.
 
 
-