Emitter usage
Emitter usage
Section titled āEmitter usageā- Via the command line
tsp compile . --emit=@typespec/http-client-csharp- Via the config
emit:  - "@typespec/http-client-csharp"The config can be extended with options as follows:
emit:  - "@typespec/http-client-csharp"options:  "@typespec/http-client-csharp":    option: valueEmitter options
Section titled āEmitter optionsāemitter-output-dir
Section titled āemitter-output-dirāType: absolutePath
Defines the emitter output directory. Defaults to {output-dir}/@typespec/http-client-csharp
See Configuring output directory for more info
api-version
Section titled āapi-versionāType: string
For TypeSpec files using the @versioned decorator, set this option to the version that should be used to generate against.
generate-protocol-methods
Section titled āgenerate-protocol-methodsāType: boolean
Set to false to skip generation of protocol methods. The default value is true.
generate-convenience-methods
Section titled āgenerate-convenience-methodsāType: boolean
Set to false to skip generation of convenience methods. The default value is true.
unreferenced-types-handling
Section titled āunreferenced-types-handlingāType: "removeOrInternalize" | "internalize" | "keepAll"
Defines the strategy on how to handle unreferenced types. The default value is removeOrInternalize.
new-project
Section titled ānew-projectāType: boolean
Set to true to overwrite the csproj if it already exists. The default value is false.
save-inputs
Section titled āsave-inputsāType: boolean
Set to true to save the tspCodeModel.json and Configuration.json files that are emitted and used as inputs to the generator. The default value is false.
package-name
Section titled āpackage-nameāType: string
Define the package name. If not specified, the first namespace defined in the TypeSpec is used as the package name.
Type: boolean
Set to true to automatically attempt to attach to a debugger when executing the C# generator. The default value is false.
logLevel
Section titled ālogLevelāType: "info" | "debug" | "verbose"
Set the log level for which to collect traces. The default value is info.
disable-xml-docs
Section titled ādisable-xml-docsāType: boolean
Set to true to disable XML documentation generation. The default value is false.
generator-name
Section titled āgenerator-nameāType: string
The name of the generator. By default this is set to ScmCodeModelGenerator. Generator authors can set this to the name of a generator that inherits from ScmCodeModelGenerator.
emitter-extension-path
Section titled āemitter-extension-pathāType: string
Allows emitter authors to specify the path to a custom emitter package, allowing you to extend the emitter behavior. This should be set to import.meta.url if you are using a custom emitter.
update-code-model
Section titled āupdate-code-modelāType: object
Allows emitter authors to specify a custom function to modify the generated code model before emitting. This is useful for modifying the code model before it is passed to the generator.
license
Section titled ālicenseāType: object
License information for the generated client code.
sdk-context-options
Section titled āsdk-context-optionsāType: object
The SDK context options that implement the CreateSdkContextOptions interface from the @azure-tools/typespec-client-generator-core package to be used by the CSharp emitter.