Class CodegenWriterDelegator<T extends CodegenWriter<T,​?>>

  • Type Parameters:
    T - The type of CodegenWriter to create and manage.

    public class CodegenWriterDelegator<T extends CodegenWriter<T,​?>>
    extends java.lang.Object
    Creates and manages CodegenWriters for files and namespaces based on Symbols created for a Shape.

    Overview

    CodegenWriterDelegator 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 CodegenWriterDelegator ensures that the state of code generator associated with the file is persisted and only written when all shapes have been generated.

    CodegenWriters are lazily created each time a new filename is requested. If a CodegenWriter is already associated with a filename, a newline (\n) is written to the file before providing access to the CodegenWriter. All of the files and CodegenWriters stored in the delegator are eventually written to the provided FileManifest when the flushWriters() method is called.

    This class is not thread-safe.

    Extending CodegenWriterDelegator

    Language-specific code generators that utilize Symbol and SymbolDependency should extend both CodegenWriterDelegator and CodegenWriter 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.

    • Method Summary

      All Methods Instance Methods Concrete Methods 
      Modifier and Type Method Description
      void flushWriters()
      Writes each pending CodegenWriter to the FileManifest.
      java.util.List<SymbolDependency> getDependencies()
      Gets all of the dependencies that have been registered in writers created by the CodegenWriterDelegator.
      java.util.Map<java.lang.String,​T> getWriters()
      Returns an immutable Map of created CodegenWriters.
      void setAutomaticSeparator​(java.lang.String automaticSeparator)
      Sets the automatic separator that is written to a CodegenWriter each time the writer is reused.
      void setOnShaperWriterUseObserver​(UseShapeWriterObserver<T> useShaperWriterObserver)
      Sets the observer to invoke when shape writers are used.
      void useFileWriter​(java.lang.String filename, java.lang.String namespace, java.util.function.Consumer<T> writerConsumer)
      Gets a previously created writer or creates a new one if needed.
      void useFileWriter​(java.lang.String filename, java.util.function.Consumer<T> writerConsumer)
      Gets a previously created CodegenWriter or creates a new one if needed.
      void useShapeWriter​(Shape shape, java.util.function.Consumer<T> writerConsumer)
      Gets or creates a writer for a Shape by converting the Shape to a Symbol.
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Method Detail

      • getDependencies

        public java.util.List<SymbolDependency> getDependencies()
        Gets all of the dependencies that have been registered in writers created by the CodegenWriterDelegator.

        This method essentially just aggregates the results of calling CodegenWriter.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).

        Returns:
        Returns all the dependencies used in each CodegenWriter.
      • flushWriters

        public void flushWriters()
        Writes each pending CodegenWriter to the FileManifest.

        The toString method is called on each writer to generate the code to write to the manifest.

        This method clears out the managed CodegenWriters, meaning a subsequent call to getWriters() will return an empty map.

        This method may be overridden as needed.

      • getWriters

        public final java.util.Map<java.lang.String,​T> getWriters()
        Returns an immutable Map of created CodegenWriters.

        Each map key is the relative filename where the code will be written in the FileManifest, and each map value is the associated CodegenWriter of type T.

        Returns:
        Returns the immutable map of files to writers.
      • useFileWriter

        public final void useFileWriter​(java.lang.String filename,
                                        java.util.function.Consumer<T> writerConsumer)
        Gets a previously created CodegenWriter 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.
        writerConsumer - Consumer that is expected to write to the CodegenWriter.
      • useFileWriter

        public final void useFileWriter​(java.lang.String filename,
                                        java.lang.String namespace,
                                        java.util.function.Consumer<T> writerConsumer)
        Gets 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 CodegenWriter.
      • useShapeWriter

        public final void useShapeWriter​(Shape shape,
                                         java.util.function.Consumer<T> writerConsumer)
        Gets or creates a writer for a Shape by converting the Shape to a Symbol.

        Any dependencies (i.e., SymbolDependency) required by the Symbol are automatically registered with the writer.

        Any imports required to declare the Symbol in 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)).

        Parameters:
        shape - Shape to create the writer for.
        writerConsumer - Consumer that is expected to write to the CodegenWriter.
      • setAutomaticSeparator

        public final void setAutomaticSeparator​(java.lang.String automaticSeparator)
        Sets the automatic separator that is written to a CodegenWriter each 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.
      • setOnShaperWriterUseObserver

        public void setOnShaperWriterUseObserver​(UseShapeWriterObserver<T> useShaperWriterObserver)
        Sets the observer to invoke when shape writers are used.

        The observer is invoked when a shape writer is used, allowing for customizations to be applied to the shape writer like invoking service providers to write default contents to generated code.

        Parameters:
        useShaperWriterObserver - Shape writer use observer.