Class CodegenDirector<W extends SymbolWriter<W,? extends ImportContainer>,I extends SmithyIntegration<S,W,C>,C extends CodegenContext<S,W,I>,S>        
- Type Parameters:
- W- Type of- SymbolWriterused to generate code.
- I- Type of- SmithyIntegrationto apply.
- C- Type of- CodegenContextto create and use.
- S- Type of settings object to pass to directed methods.
DirectedCodegen.- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidchangeStringEnumsToEnumShapes(boolean synthesizeEnumNames) Changes each compatible string shape with the enum trait to an enum shape.voidGenerates dedicated input and output shapes for every operation if the operation doesn't already have them.voidcreateDedicatedInputsAndOutputs(String inputSuffix, String outputSuffix) Generates dedicated input and output shapes for every operation if the operation doesn't already have them.voiddirectedCodegen(DirectedCodegen<C, S, I> directedCodegen) Sets the requiredDirectedCodegenimplementation to invoke.voidfileManifest(FileManifest fileManifest) Sets the required file manifest used to write files to disk.voidFlattens service-level pagination information into operation pagination traits.voidintegrationClass(Class<I> integrationClass) Sets the required class used for SmithyIntegrations.voidintegrationClassLoader(ClassLoader classLoader) Sets a custom class loader for finding implementations ofSmithyIntegration.voidintegrationFinder(Supplier<Iterable<I>> integrationFinder) Sets a custom implementation for findingSmithyIntegrations.voidintegrationSettings(ObjectNode integrationSettings) Sets the settings node to be passed to integrations.voidMakesidempotencyTokenfieldsclientOptional.voidSets the required model to generate from.voidSet to true to applysimplifyModelForServiceCodegen(software.amazon.smithy.model.Model, software.amazon.smithy.model.shapes.ShapeId, software.amazon.smithy.model.transform.ModelTransformer)prior to code generation.voidremoveShapesDeprecatedBeforeDate(String relativeDate) Removes any shapes deprecated before the specified date.voidremoveShapesDeprecatedBeforeVersion(String relativeVersion) Removes any shapes deprecated before the specified version.voidrun()Finalizes the Runner and performs directed code generation.voidSets the required service being generated.Sets the required settings object used for code generation using aNode.voidSets the required settings object used for code generation.voidSets the shapes order for code generation.static ModelsimplifyModelForServiceCodegen(Model model, ShapeId service, ModelTransformer transformer) Simplifies a Smithy model for code generation of a single service.voidSorts all members of the model prior to codegen.
- 
Constructor Details- 
CodegenDirectorpublic CodegenDirector()
 
- 
- 
Method Details- 
simplifyModelForServiceCodegenpublic static Model simplifyModelForServiceCodegen(Model model, ShapeId service, ModelTransformer transformer) Simplifies a Smithy model for code generation of a single service.- Flattens error hierarchies onto every operation.
- Flattens mixins
 Note: This transform is applied automatically by a code generator if performDefaultCodegenTransforms()is set to true.- Parameters:
- model- Model being code generated.
- service- Service being generated.
- transformer- Model transformer to use.
- Returns:
- Returns the updated model.
 
- 
integrationClassSets the required class used for SmithyIntegrations.- Parameters:
- integrationClass- SmithyIntegration class.
 
- 
serviceSets the required service being generated.- Parameters:
- service- Service to generate.
 
- 
directedCodegenSets the requiredDirectedCodegenimplementation to invoke.- Parameters:
- directedCodegen- Directed code generator to run.
 
- 
modelSets the required model to generate from.- Parameters:
- model- Model to generate from.
 
- 
settingsSets the required settings object used for code generation.integrationSettingsMUST also be set.- Parameters:
- settings- Settings object.
 
- 
settingsSets the required settings object used for code generation using aNode.A Node value is used by Smithy-Build plugins to configure settings. This method is a helper method that uses Smithy's fairly simple object-mapper to deserialize a node into the desired settings type. You will need to manually deserialize your settings if using types that are not supported by Smithy's NodeMapper.This will also set integrationSettingsif theintegrationskey is present.- Parameters:
- settingsType- Settings type to deserialize into.
- settingsNode- Settings node value to deserialize.
- Returns:
- Returns the deserialized settings as this is needed to provide a service shape ID.
 
- 
integrationSettingsSets the settings node to be passed to integrations.Generators MUST set this with the integrationskey from their plugin settings.{ "version": "1.0", "projections": { "codegen-projection": { "plugins": { "code-generator": { "service": "com.example#DocumentedService", "integrations": { "my-integration": { "example-setting": "foo" } } } } } } }In this example, the value of the integrationskey is what must be passed to this method. The value of themy-integrationkey will then be provided to an integration with the namemy-integration.- Parameters:
- integrationSettings- Settings used to configure integrations.
 
- 
fileManifestSets the required file manifest used to write files to disk.- Parameters:
- fileManifest- File manifest to write files.
 
- 
integrationFinderSets a custom implementation for findingSmithyIntegrations.Most implementations can use integrationClassLoader(ClassLoader).- Parameters:
- integrationFinder- Smithy integration finder.
 
- 
integrationClassLoaderSets a custom class loader for finding implementations ofSmithyIntegration.- Parameters:
- classLoader- Class loader to find integrations.* @return Returns self.
 
- 
performDefaultCodegenTransformspublic void performDefaultCodegenTransforms()Set to true to applysimplifyModelForServiceCodegen(software.amazon.smithy.model.Model, software.amazon.smithy.model.shapes.ShapeId, software.amazon.smithy.model.transform.ModelTransformer)prior to code generation.
- 
createDedicatedInputsAndOutputspublic void createDedicatedInputsAndOutputs()Generates dedicated input and output shapes for every operation if the operation doesn't already have them.This method uses "Input" as the default suffix for input, and "Output" as the default suffix for output shapes. Use createDedicatedInputsAndOutputs(String, String)to use custom suffixes.
- 
createDedicatedInputsAndOutputsGenerates dedicated input and output shapes for every operation if the operation doesn't already have them.- Parameters:
- inputSuffix- Suffix to use for input shapes (e.g., "Input").
- outputSuffix- Suffix to use for output shapes (e.g., "Output").
- See Also:
 
- 
removeShapesDeprecatedBeforeDateRemoves any shapes deprecated before the specified date.- Parameters:
- relativeDate- Relative date, in YYYY-MM-DD format, to use to filter out deprecated shapes.
- See Also:
 
- 
removeShapesDeprecatedBeforeVersionRemoves any shapes deprecated before the specified version.- Parameters:
- relativeVersion- Version, in SemVer format, to use to filter out deprecated shapes.
- See Also:
 
- 
makeIdempotencyTokensClientOptionalpublic void makeIdempotencyTokensClientOptional()MakesidempotencyTokenfieldsclientOptional.
- 
changeStringEnumsToEnumShapespublic void changeStringEnumsToEnumShapes(boolean synthesizeEnumNames) Changes each compatible string shape with the enum trait to an enum shape.- Parameters:
- synthesizeEnumNames- Whether enums without names should have names synthesized if possible.
- See Also:
 
- 
flattenPaginationInfoIntoOperationspublic void flattenPaginationInfoIntoOperations()Flattens service-level pagination information into operation pagination traits.
- 
shapeGenerationOrderSets the shapes order for code generation.CodegenDirector order the shapes appropriately before passing them to the code generators. The default order is topological, and can be overridden with this method - Parameters:
- order- the order to use for the shape generation process.
 
- 
sortMemberspublic void sortMembers()Sorts all members of the model prior to codegen.This should only be used by languages where changing the order of members in a structure or union is a backward compatible change (i.e., not C, C++, Rust, etc). Once this is performed, there's no need to ever explicitly sort members throughout the rest of code generation. 
- 
runpublic void run()Finalizes the Runner and performs directed code generation.- Throws:
- IllegalStateException- if a required value has not been provided.
 
 
-