jsii-pacmak 1.38.0 → 1.42.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/builder.js CHANGED
@@ -15,10 +15,16 @@ class OneByOneBuilder {
15
15
  this.options = options;
16
16
  }
17
17
  async buildModules() {
18
- const promises = this.modules.map((module) => this.options.codeOnly
19
- ? this.generateModuleCode(module, this.options)
20
- : this.buildModule(module, this.options));
21
- await Promise.all(promises);
18
+ for (const module of this.modules) {
19
+ if (this.options.codeOnly) {
20
+ // eslint-disable-next-line no-await-in-loop
21
+ await this.generateModuleCode(module, this.options);
22
+ }
23
+ else {
24
+ // eslint-disable-next-line no-await-in-loop
25
+ await this.buildModule(module, this.options);
26
+ }
27
+ }
22
28
  }
23
29
  async generateModuleCode(module, options) {
24
30
  const outputDir = this.finalOutputDir(module, options);
@@ -69,4 +75,4 @@ class OneByOneBuilder {
69
75
  }
70
76
  }
71
77
  exports.OneByOneBuilder = OneByOneBuilder;
72
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.js","sourceRoot":"","sources":["builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Rosetta } from 'jsii-rosetta';\nimport * as path from 'path';\n\nimport * as logging from './logging';\nimport { JsiiModule } from './packaging';\nimport { TargetConstructor, Target } from './target';\nimport { TargetName } from './targets';\nimport { Scratch } from './util';\n\nexport interface BuildOptions {\n  /**\n   * Whether to fingerprint the produced artifacts.\n   * @default true\n   */\n  fingerprint?: boolean;\n\n  /**\n   * Whether artifacts should be re-build even if their fingerprints look up-to-date.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Arguments provided by the user (how they are used is target-dependent)\n   */\n  arguments: { readonly [name: string]: any };\n\n  /**\n   * Only generate code, don't build\n   */\n  codeOnly?: boolean;\n\n  /**\n   * Whether or not to clean\n   */\n  clean?: boolean;\n\n  /**\n   * Whether to add an additional subdirectory for the target language\n   */\n  languageSubdirectory?: boolean;\n\n  /**\n   * The Rosetta instance to load examples from\n   */\n  rosetta: Rosetta;\n}\n\n/**\n * Interface for classes that can build language targets\n *\n * Building can happen one target at a time, or multiple targets at a time.\n */\nexport interface TargetBuilder {\n  buildModules(): Promise<void>;\n}\n\n/**\n * Builds the targets for the given language sequentially\n */\nexport class OneByOneBuilder implements TargetBuilder {\n  public constructor(\n    private readonly targetName: TargetName,\n    private readonly targetConstructor: TargetConstructor,\n    private readonly modules: readonly JsiiModule[],\n    private readonly options: BuildOptions,\n  ) {}\n\n  public async buildModules(): Promise<void> {\n    const promises = this.modules.map((module) =>\n      this.options.codeOnly\n        ? this.generateModuleCode(module, this.options)\n        : this.buildModule(module, this.options),\n    );\n    await Promise.all(promises);\n  }\n\n  private async generateModuleCode(module: JsiiModule, options: BuildOptions) {\n    const outputDir = this.finalOutputDir(module, options);\n    logging.debug(`Generating ${this.targetName} code into ${outputDir}`);\n    await this.makeTarget(module, options).generateCode(\n      outputDir,\n      module.tarball,\n    );\n  }\n\n  private async buildModule(module: JsiiModule, options: BuildOptions) {\n    const target = this.makeTarget(module, options);\n    const outputDir = this.finalOutputDir(module, options);\n\n    const src = await Scratch.make((tmpdir) => {\n      logging.debug(`Generating ${this.targetName} code into ${tmpdir}`);\n      return target.generateCode(tmpdir, module.tarball);\n    });\n\n    try {\n      logging.debug(`Building ${src.directory} into ${outputDir}`);\n      return await target.build(src.directory, outputDir);\n    } catch (err) {\n      logging.warn(`Failed building ${this.targetName}`);\n      return await Promise.reject(err);\n    } finally {\n      if (options.clean) {\n        logging.debug(`Cleaning ${src.directory}`);\n        await src.cleanup();\n      } else {\n        logging.info(\n          `Generated code for ${this.targetName} retained at ${src.directory}`,\n        );\n      }\n    }\n  }\n\n  private makeTarget(module: JsiiModule, options: BuildOptions): Target {\n    return new this.targetConstructor({\n      targetName: this.targetName,\n      packageDir: module.moduleDirectory,\n      assembly: module.assembly,\n      fingerprint: options.fingerprint,\n      force: options.force,\n      arguments: options.arguments,\n      rosetta: options.rosetta,\n    });\n  }\n\n  private finalOutputDir(module: JsiiModule, options: BuildOptions): string {\n    if (options.languageSubdirectory) {\n      return path.join(module.outputDirectory, this.targetName);\n    }\n    return module.outputDirectory;\n  }\n}\n"]}
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.js","sourceRoot":"","sources":["builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Rosetta } from 'jsii-rosetta';\nimport * as path from 'path';\n\nimport * as logging from './logging';\nimport { JsiiModule } from './packaging';\nimport { TargetConstructor, Target } from './target';\nimport { TargetName } from './targets';\nimport { Scratch } from './util';\n\nexport interface BuildOptions {\n  /**\n   * Whether to fingerprint the produced artifacts.\n   * @default true\n   */\n  fingerprint?: boolean;\n\n  /**\n   * Whether artifacts should be re-build even if their fingerprints look up-to-date.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Arguments provided by the user (how they are used is target-dependent)\n   */\n  arguments: { readonly [name: string]: any };\n\n  /**\n   * Only generate code, don't build\n   */\n  codeOnly?: boolean;\n\n  /**\n   * Whether or not to clean\n   */\n  clean?: boolean;\n\n  /**\n   * Whether to add an additional subdirectory for the target language\n   */\n  languageSubdirectory?: boolean;\n\n  /**\n   * The Rosetta instance to load examples from\n   */\n  rosetta: Rosetta;\n}\n\n/**\n * Interface for classes that can build language targets\n *\n * Building can happen one target at a time, or multiple targets at a time.\n */\nexport interface TargetBuilder {\n  buildModules(): Promise<void>;\n}\n\n/**\n * Builds the targets for the given language sequentially\n */\nexport class OneByOneBuilder implements TargetBuilder {\n  public constructor(\n    private readonly targetName: TargetName,\n    private readonly targetConstructor: TargetConstructor,\n    private readonly modules: readonly JsiiModule[],\n    private readonly options: BuildOptions,\n  ) {}\n\n  public async buildModules(): Promise<void> {\n    for (const module of this.modules) {\n      if (this.options.codeOnly) {\n        // eslint-disable-next-line no-await-in-loop\n        await this.generateModuleCode(module, this.options);\n      } else {\n        // eslint-disable-next-line no-await-in-loop\n        await this.buildModule(module, this.options);\n      }\n    }\n  }\n\n  private async generateModuleCode(module: JsiiModule, options: BuildOptions) {\n    const outputDir = this.finalOutputDir(module, options);\n    logging.debug(`Generating ${this.targetName} code into ${outputDir}`);\n    await this.makeTarget(module, options).generateCode(\n      outputDir,\n      module.tarball,\n    );\n  }\n\n  private async buildModule(module: JsiiModule, options: BuildOptions) {\n    const target = this.makeTarget(module, options);\n    const outputDir = this.finalOutputDir(module, options);\n\n    const src = await Scratch.make((tmpdir) => {\n      logging.debug(`Generating ${this.targetName} code into ${tmpdir}`);\n      return target.generateCode(tmpdir, module.tarball);\n    });\n\n    try {\n      logging.debug(`Building ${src.directory} into ${outputDir}`);\n      return await target.build(src.directory, outputDir);\n    } catch (err) {\n      logging.warn(`Failed building ${this.targetName}`);\n      return await Promise.reject(err);\n    } finally {\n      if (options.clean) {\n        logging.debug(`Cleaning ${src.directory}`);\n        await src.cleanup();\n      } else {\n        logging.info(\n          `Generated code for ${this.targetName} retained at ${src.directory}`,\n        );\n      }\n    }\n  }\n\n  private makeTarget(module: JsiiModule, options: BuildOptions): Target {\n    return new this.targetConstructor({\n      targetName: this.targetName,\n      packageDir: module.moduleDirectory,\n      assembly: module.assembly,\n      fingerprint: options.fingerprint,\n      force: options.force,\n      arguments: options.arguments,\n      rosetta: options.rosetta,\n    });\n  }\n\n  private finalOutputDir(module: JsiiModule, options: BuildOptions): string {\n    if (options.languageSubdirectory) {\n      return path.join(module.outputDirectory, this.targetName);\n    }\n    return module.outputDirectory;\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import * as spec from '@jsii/spec';
2
2
  import { CodeMaker } from 'codemaker';
3
- import { Rosetta } from 'jsii-rosetta';
3
+ import { Rosetta, ApiLocation } from 'jsii-rosetta';
4
4
  /**
5
5
  * Generates the Jsii attributes and calls for the .NET runtime
6
6
  *
@@ -22,8 +22,8 @@ export declare class DotNetDocGenerator {
22
22
  * Returns
23
23
  * Remarks (includes examples, links, deprecated)
24
24
  */
25
- emitDocs(obj: spec.Documentable): void;
26
- emitMarkdownAsRemarks(markdown: string | undefined): void;
25
+ emitDocs(obj: spec.Documentable, apiLocation: ApiLocation): void;
26
+ emitMarkdownAsRemarks(markdown: string | undefined, apiLocation: ApiLocation): void;
27
27
  /**
28
28
  * Returns the lines that should go into the <remarks> section
29
29
  */
@@ -29,7 +29,7 @@ class DotNetDocGenerator {
29
29
  * Returns
30
30
  * Remarks (includes examples, links, deprecated)
31
31
  */
32
- emitDocs(obj) {
32
+ emitDocs(obj, apiLocation) {
33
33
  const docs = obj.docs;
34
34
  // The docs may be undefined at the method level but not the parameters level
35
35
  this.emitXmlDoc('summary', _utils_1.renderSummary(obj.docs));
@@ -57,7 +57,7 @@ class DotNetDocGenerator {
57
57
  // Remarks does not use emitXmlDoc() because the remarks can contain code blocks
58
58
  // which are fenced with <code> tags, which would be escaped to
59
59
  // &lt;code&gt; if we used the xml builder.
60
- const remarks = this.renderRemarks(docs);
60
+ const remarks = this.renderRemarks(docs, apiLocation);
61
61
  if (remarks.length > 0) {
62
62
  this.code.line('/// <remarks>');
63
63
  remarks.forEach((r) => this.code.line(`/// ${r}`.trimRight()));
@@ -65,15 +65,15 @@ class DotNetDocGenerator {
65
65
  }
66
66
  if (docs.example) {
67
67
  this.code.line('/// <example>');
68
- this.emitXmlDoc('code', this.convertExample(docs.example));
68
+ this.emitXmlDoc('code', this.convertExample(docs.example, apiLocation));
69
69
  this.code.line('/// </example>');
70
70
  }
71
71
  }
72
- emitMarkdownAsRemarks(markdown) {
72
+ emitMarkdownAsRemarks(markdown, apiLocation) {
73
73
  if (!markdown) {
74
74
  return;
75
75
  }
76
- const translated = jsii_rosetta_1.markDownToXmlDoc(this.convertSamplesInMarkdown(markdown));
76
+ const translated = jsii_rosetta_1.markDownToXmlDoc(this.convertSamplesInMarkdown(markdown, apiLocation));
77
77
  const lines = translated.split('\n');
78
78
  this.code.line('/// <remarks>');
79
79
  for (const line of lines) {
@@ -84,11 +84,11 @@ class DotNetDocGenerator {
84
84
  /**
85
85
  * Returns the lines that should go into the <remarks> section
86
86
  */
87
- renderRemarks(docs) {
87
+ renderRemarks(docs, apiLocation) {
88
88
  var _a;
89
89
  const ret = [];
90
90
  if (docs.remarks) {
91
- const translated = jsii_rosetta_1.markDownToXmlDoc(this.convertSamplesInMarkdown(docs.remarks));
91
+ const translated = jsii_rosetta_1.markDownToXmlDoc(this.convertSamplesInMarkdown(docs.remarks, apiLocation));
92
92
  ret.push(...translated.split('\n'));
93
93
  ret.push('');
94
94
  }
@@ -124,16 +124,12 @@ class DotNetDocGenerator {
124
124
  ret.push('');
125
125
  }
126
126
  }
127
- convertExample(example) {
128
- const snippet = jsii_rosetta_1.typeScriptSnippetFromSource(example, 'example', jsii_rosetta_1.enforcesStrictMode(this.assembly));
129
- const translated = this.rosetta.translateSnippet(snippet, jsii_rosetta_1.TargetLanguage.CSHARP);
130
- if (!translated) {
131
- return example;
132
- }
127
+ convertExample(example, apiLocation) {
128
+ const translated = this.rosetta.translateExample(apiLocation, example, jsii_rosetta_1.TargetLanguage.CSHARP, jsii_rosetta_1.enforcesStrictMode(this.assembly));
133
129
  return this.prefixDisclaimer(translated);
134
130
  }
135
- convertSamplesInMarkdown(markdown) {
136
- return this.rosetta.translateSnippetsInMarkdown(markdown, jsii_rosetta_1.TargetLanguage.CSHARP, jsii_rosetta_1.enforcesStrictMode(this.assembly), (trans) => ({
131
+ convertSamplesInMarkdown(markdown, api) {
132
+ return this.rosetta.translateSnippetsInMarkdown(api, markdown, jsii_rosetta_1.TargetLanguage.CSHARP, jsii_rosetta_1.enforcesStrictMode(this.assembly), (trans) => ({
137
133
  language: trans.language,
138
134
  source: this.prefixDisclaimer(trans),
139
135
  }));
@@ -172,4 +168,4 @@ function shouldMentionStability(s) {
172
168
  // Don't render "stable" or "external", those are both stable by implication
173
169
  return s === spec.Stability.Deprecated || s === spec.Stability.Experimental;
174
170
  }
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dotnetdocgenerator.js","sourceRoot":"","sources":["dotnetdocgenerator.ts"],"names":[],"mappings":"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","sourcesContent":["import * as spec from '@jsii/spec';\nimport { CodeMaker } from 'codemaker';\nimport {\n  Rosetta,\n  TargetLanguage,\n  Translation,\n  enforcesStrictMode,\n  typeScriptSnippetFromSource,\n  markDownToXmlDoc,\n} from 'jsii-rosetta';\nimport * as xmlbuilder from 'xmlbuilder';\n\nimport {\n  INCOMPLETE_DISCLAIMER_COMPILING,\n  INCOMPLETE_DISCLAIMER_NONCOMPILING,\n} from '..';\nimport { renderSummary } from '../_utils';\nimport { DotNetNameUtils } from './nameutils';\n\n/**\n * Generates the Jsii attributes and calls for the .NET runtime\n *\n * Uses the same instance of CodeMaker as the rest of the code\n */\nexport class DotNetDocGenerator {\n  private readonly code: CodeMaker;\n  private readonly nameutils: DotNetNameUtils = new DotNetNameUtils();\n\n  public constructor(\n    code: CodeMaker,\n    private readonly rosetta: Rosetta,\n    private readonly assembly: spec.Assembly,\n  ) {\n    this.code = code;\n  }\n\n  /**\n   * Emits all documentation depending on what is available in the jsii model\n   *\n   * Used by all kind of members + classes, interfaces, enums\n   * Order should be\n   * Summary\n   * Param\n   * Returns\n   * Remarks (includes examples, links, deprecated)\n   */\n  public emitDocs(obj: spec.Documentable): void {\n    const docs = obj.docs;\n\n    // The docs may be undefined at the method level but not the parameters level\n    this.emitXmlDoc('summary', renderSummary(obj.docs));\n\n    // Handling parameters only if the obj is a method\n    const objMethod = obj as spec.Method;\n    if (objMethod.parameters) {\n      objMethod.parameters.forEach((param) => {\n        // Remove any slug `@` from the parameter name - it's not supposed to show up here.\n        const paramName = this.nameutils\n          .convertParameterName(param.name)\n          .replace(/^@/, '');\n        this.emitXmlDoc('param', param.docs?.summary ?? '', {\n          attributes: { name: paramName },\n        });\n      });\n    }\n\n    // At this pdocfx namespacedocd a valid instance of docs\n    if (!docs) {\n      return;\n    }\n\n    if (docs.returns) {\n      this.emitXmlDoc('returns', docs.returns);\n    }\n\n    // Remarks does not use emitXmlDoc() because the remarks can contain code blocks\n    // which are fenced with <code> tags, which would be escaped to\n    // &lt;code&gt; if we used the xml builder.\n    const remarks = this.renderRemarks(docs);\n    if (remarks.length > 0) {\n      this.code.line('/// <remarks>');\n      remarks.forEach((r) => this.code.line(`/// ${r}`.trimRight()));\n      this.code.line('/// </remarks>');\n    }\n\n    if (docs.example) {\n      this.code.line('/// <example>');\n      this.emitXmlDoc('code', this.convertExample(docs.example));\n      this.code.line('/// </example>');\n    }\n  }\n\n  public emitMarkdownAsRemarks(markdown: string | undefined) {\n    if (!markdown) {\n      return;\n    }\n\n    const translated = markDownToXmlDoc(\n      this.convertSamplesInMarkdown(markdown),\n    );\n    const lines = translated.split('\\n');\n\n    this.code.line('/// <remarks>');\n    for (const line of lines) {\n      this.code.line(`/// ${line}`.trimRight());\n    }\n    this.code.line('/// </remarks>');\n  }\n\n  /**\n   * Returns the lines that should go into the <remarks> section\n   */\n  private renderRemarks(docs: spec.Docs): string[] {\n    const ret: string[] = [];\n\n    if (docs.remarks) {\n      const translated = markDownToXmlDoc(\n        this.convertSamplesInMarkdown(docs.remarks),\n      );\n      ret.push(...translated.split('\\n'));\n      ret.push('');\n    }\n\n    // All the \"tags\" need to be rendered with empyt lines between them or they'll be word wrapped.\n\n    if (docs.default) {\n      emitDocAttribute('default', docs.default);\n    }\n    if (docs.stability && shouldMentionStability(docs.stability)) {\n      emitDocAttribute(\n        'stability',\n        this.nameutils.capitalizeWord(docs.stability),\n      );\n    }\n    if (docs.see) {\n      emitDocAttribute('see', docs.see);\n    }\n    if (docs.subclassable) {\n      emitDocAttribute('subclassable', '');\n    }\n    for (const [k, v] of Object.entries(docs.custom ?? {})) {\n      const extraSpace = k === 'link' ? ' ' : ''; // Extra space for '@link' to keep unit tests happy\n      emitDocAttribute(k, v + extraSpace);\n    }\n\n    // Remove leading and trailing empty lines\n    while (ret.length > 0 && ret[0] === '') {\n      ret.shift();\n    }\n    while (ret.length > 0 && ret[ret.length - 1] === '') {\n      ret.pop();\n    }\n\n    return ret;\n\n    function emitDocAttribute(name: string, contents: string) {\n      const ls = contents.split('\\n');\n      ret.push(`<strong>${ucFirst(name)}</strong>: ${ls[0]}`);\n      ret.push(...ls.slice(1));\n      ret.push('');\n    }\n  }\n\n  private convertExample(example: string): string {\n    const snippet = typeScriptSnippetFromSource(\n      example,\n      'example',\n      enforcesStrictMode(this.assembly),\n    );\n    const translated = this.rosetta.translateSnippet(\n      snippet,\n      TargetLanguage.CSHARP,\n    );\n    if (!translated) {\n      return example;\n    }\n    return this.prefixDisclaimer(translated);\n  }\n\n  private convertSamplesInMarkdown(markdown: string): string {\n    return this.rosetta.translateSnippetsInMarkdown(\n      markdown,\n      TargetLanguage.CSHARP,\n      enforcesStrictMode(this.assembly),\n      (trans) => ({\n        language: trans.language,\n        source: this.prefixDisclaimer(trans),\n      }),\n    );\n  }\n\n  private prefixDisclaimer(translated: Translation) {\n    if (translated.didCompile && INCOMPLETE_DISCLAIMER_COMPILING) {\n      return `// ${INCOMPLETE_DISCLAIMER_COMPILING}\\n${translated.source}`;\n    }\n    if (!translated.didCompile && INCOMPLETE_DISCLAIMER_NONCOMPILING) {\n      return `// ${INCOMPLETE_DISCLAIMER_NONCOMPILING}\\n${translated.source}`;\n    }\n    return translated.source;\n  }\n\n  private emitXmlDoc(\n    tag: string,\n    content: string,\n    { attributes = {} }: { attributes?: { [name: string]: string } } = {},\n  ): void {\n    if (!content) {\n      return;\n    }\n\n    const xml = xmlbuilder.create(tag, { headless: true }).text(content);\n    for (const [name, value] of Object.entries(attributes)) {\n      xml.att(name, value);\n    }\n    const xmlstring = xml.end({ allowEmpty: true, pretty: false });\n\n    for (const line of xmlstring.split('\\n').map((x) => x.trim())) {\n      this.code.line(`/// ${line}`);\n    }\n  }\n}\n\n/**\n * Uppercase the first letter\n */\nfunction ucFirst(x: string) {\n  return x.substr(0, 1).toUpperCase() + x.substr(1);\n}\n\nfunction shouldMentionStability(s: spec.Stability) {\n  // Don't render \"stable\" or \"external\", those are both stable by implication\n  return s === spec.Stability.Deprecated || s === spec.Stability.Experimental;\n}\n"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dotnetdocgenerator.js","sourceRoot":"","sources":["dotnetdocgenerator.ts"],"names":[],"mappings":"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","sourcesContent":["import * as spec from '@jsii/spec';\nimport { CodeMaker } from 'codemaker';\nimport {\n  Rosetta,\n  TargetLanguage,\n  Translation,\n  enforcesStrictMode,\n  markDownToXmlDoc,\n  ApiLocation,\n} from 'jsii-rosetta';\nimport * as xmlbuilder from 'xmlbuilder';\n\nimport {\n  INCOMPLETE_DISCLAIMER_COMPILING,\n  INCOMPLETE_DISCLAIMER_NONCOMPILING,\n} from '..';\nimport { renderSummary } from '../_utils';\nimport { DotNetNameUtils } from './nameutils';\n\n/**\n * Generates the Jsii attributes and calls for the .NET runtime\n *\n * Uses the same instance of CodeMaker as the rest of the code\n */\nexport class DotNetDocGenerator {\n  private readonly code: CodeMaker;\n  private readonly nameutils: DotNetNameUtils = new DotNetNameUtils();\n\n  public constructor(\n    code: CodeMaker,\n    private readonly rosetta: Rosetta,\n    private readonly assembly: spec.Assembly,\n  ) {\n    this.code = code;\n  }\n\n  /**\n   * Emits all documentation depending on what is available in the jsii model\n   *\n   * Used by all kind of members + classes, interfaces, enums\n   * Order should be\n   * Summary\n   * Param\n   * Returns\n   * Remarks (includes examples, links, deprecated)\n   */\n  public emitDocs(obj: spec.Documentable, apiLocation: ApiLocation): void {\n    const docs = obj.docs;\n\n    // The docs may be undefined at the method level but not the parameters level\n    this.emitXmlDoc('summary', renderSummary(obj.docs));\n\n    // Handling parameters only if the obj is a method\n    const objMethod = obj as spec.Method;\n    if (objMethod.parameters) {\n      objMethod.parameters.forEach((param) => {\n        // Remove any slug `@` from the parameter name - it's not supposed to show up here.\n        const paramName = this.nameutils\n          .convertParameterName(param.name)\n          .replace(/^@/, '');\n        this.emitXmlDoc('param', param.docs?.summary ?? '', {\n          attributes: { name: paramName },\n        });\n      });\n    }\n\n    // At this pdocfx namespacedocd a valid instance of docs\n    if (!docs) {\n      return;\n    }\n\n    if (docs.returns) {\n      this.emitXmlDoc('returns', docs.returns);\n    }\n\n    // Remarks does not use emitXmlDoc() because the remarks can contain code blocks\n    // which are fenced with <code> tags, which would be escaped to\n    // &lt;code&gt; if we used the xml builder.\n    const remarks = this.renderRemarks(docs, apiLocation);\n    if (remarks.length > 0) {\n      this.code.line('/// <remarks>');\n      remarks.forEach((r) => this.code.line(`/// ${r}`.trimRight()));\n      this.code.line('/// </remarks>');\n    }\n\n    if (docs.example) {\n      this.code.line('/// <example>');\n      this.emitXmlDoc('code', this.convertExample(docs.example, apiLocation));\n      this.code.line('/// </example>');\n    }\n  }\n\n  public emitMarkdownAsRemarks(\n    markdown: string | undefined,\n    apiLocation: ApiLocation,\n  ) {\n    if (!markdown) {\n      return;\n    }\n\n    const translated = markDownToXmlDoc(\n      this.convertSamplesInMarkdown(markdown, apiLocation),\n    );\n    const lines = translated.split('\\n');\n\n    this.code.line('/// <remarks>');\n    for (const line of lines) {\n      this.code.line(`/// ${line}`.trimRight());\n    }\n    this.code.line('/// </remarks>');\n  }\n\n  /**\n   * Returns the lines that should go into the <remarks> section\n   */\n  private renderRemarks(docs: spec.Docs, apiLocation: ApiLocation): string[] {\n    const ret: string[] = [];\n\n    if (docs.remarks) {\n      const translated = markDownToXmlDoc(\n        this.convertSamplesInMarkdown(docs.remarks, apiLocation),\n      );\n      ret.push(...translated.split('\\n'));\n      ret.push('');\n    }\n\n    // All the \"tags\" need to be rendered with empyt lines between them or they'll be word wrapped.\n\n    if (docs.default) {\n      emitDocAttribute('default', docs.default);\n    }\n    if (docs.stability && shouldMentionStability(docs.stability)) {\n      emitDocAttribute(\n        'stability',\n        this.nameutils.capitalizeWord(docs.stability),\n      );\n    }\n    if (docs.see) {\n      emitDocAttribute('see', docs.see);\n    }\n    if (docs.subclassable) {\n      emitDocAttribute('subclassable', '');\n    }\n    for (const [k, v] of Object.entries(docs.custom ?? {})) {\n      const extraSpace = k === 'link' ? ' ' : ''; // Extra space for '@link' to keep unit tests happy\n      emitDocAttribute(k, v + extraSpace);\n    }\n\n    // Remove leading and trailing empty lines\n    while (ret.length > 0 && ret[0] === '') {\n      ret.shift();\n    }\n    while (ret.length > 0 && ret[ret.length - 1] === '') {\n      ret.pop();\n    }\n\n    return ret;\n\n    function emitDocAttribute(name: string, contents: string) {\n      const ls = contents.split('\\n');\n      ret.push(`<strong>${ucFirst(name)}</strong>: ${ls[0]}`);\n      ret.push(...ls.slice(1));\n      ret.push('');\n    }\n  }\n\n  private convertExample(example: string, apiLocation: ApiLocation): string {\n    const translated = this.rosetta.translateExample(\n      apiLocation,\n      example,\n      TargetLanguage.CSHARP,\n      enforcesStrictMode(this.assembly),\n    );\n    return this.prefixDisclaimer(translated);\n  }\n\n  private convertSamplesInMarkdown(markdown: string, api: ApiLocation): string {\n    return this.rosetta.translateSnippetsInMarkdown(\n      api,\n      markdown,\n      TargetLanguage.CSHARP,\n      enforcesStrictMode(this.assembly),\n      (trans) => ({\n        language: trans.language,\n        source: this.prefixDisclaimer(trans),\n      }),\n    );\n  }\n\n  private prefixDisclaimer(translated: Translation) {\n    if (translated.didCompile && INCOMPLETE_DISCLAIMER_COMPILING) {\n      return `// ${INCOMPLETE_DISCLAIMER_COMPILING}\\n${translated.source}`;\n    }\n    if (!translated.didCompile && INCOMPLETE_DISCLAIMER_NONCOMPILING) {\n      return `// ${INCOMPLETE_DISCLAIMER_NONCOMPILING}\\n${translated.source}`;\n    }\n    return translated.source;\n  }\n\n  private emitXmlDoc(\n    tag: string,\n    content: string,\n    { attributes = {} }: { attributes?: { [name: string]: string } } = {},\n  ): void {\n    if (!content) {\n      return;\n    }\n\n    const xml = xmlbuilder.create(tag, { headless: true }).text(content);\n    for (const [name, value] of Object.entries(attributes)) {\n      xml.att(name, value);\n    }\n    const xmlstring = xml.end({ allowEmpty: true, pretty: false });\n\n    for (const line of xmlstring.split('\\n').map((x) => x.trim())) {\n      this.code.line(`/// ${line}`);\n    }\n  }\n}\n\n/**\n * Uppercase the first letter\n */\nfunction ucFirst(x: string) {\n  return x.substr(0, 1).toUpperCase() + x.substr(1);\n}\n\nfunction shouldMentionStability(s: spec.Stability) {\n  // Don't render \"stable\" or \"external\", those are both stable by implication\n  return s === spec.Stability.Deprecated || s === spec.Stability.Experimental;\n}\n"]}