jsii-pacmak 1.41.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.
@@ -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"]}