UNPKG

jsii-docgen

Version:

generates api docs for jsii modules

243 lines 26.5 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); Object.defineProperty(exports, "__esModule", { value: true }); exports.TypeScriptTranspile = void 0; const reflect = __importStar(require("jsii-reflect")); const transpile = __importStar(require("./transpile")); const schema_1 = require("../schema"); // eslint-disable-next-line @typescript-eslint/no-require-imports const Case = require('case'); // Helpers const toCamelCase = (text) => { return Case.camel(text !== null && text !== void 0 ? text : ''); }; const formatArguments = (inputs) => { return inputs.join(', '); }; const formatStructInitialization = (type) => { const target = type.submodule ? `${type.namespace}.${type.name}` : type.name; return `const ${toCamelCase(type.name)}: ${target} = { ... }`; }; const formatClassInitialization = (type, inputs) => { const target = type.submodule ? `${type.namespace}.${type.name}` : type.name; return `new ${target}(${formatArguments(inputs)})`; }; const formatInvocation = (type, inputs, method) => { let target = type.submodule ? `${type.namespace}.${type.name}` : type.name; if (method) { target = `${target}.${method}`; } return `${target}(${formatArguments(inputs)})`; }; const formatImport = (type) => { if (type.submodule) { return `import { ${type.submodule} } from '${type.module}'`; } else { return `import { ${type.name} } from '${type.module}'`; } }; const formatSignature = (name, inputs, returns) => { return `public ${name}(${formatArguments(inputs)})${returns ? ': ' + returns : ''}`; }; /** * A TypeScript transpiler. */ class TypeScriptTranspile extends transpile.TranspileBase { constructor() { super(transpile.Language.TYPESCRIPT); } readme(readme) { return readme; } unionOf(types) { return `${types.join(' | ')}`; } listOf(type) { return `${type}[]`; } variadicOf(type) { return `...${this.listOf(type)}`; } mapOf(type) { return `{[ key: string ]: ${type}}`; } any() { return 'any'; } void() { return 'void'; } boolean() { return 'boolean'; } str() { return 'string'; } number() { return 'number'; } date() { return 'Date'; } json() { return 'object'; } enum(enu) { return { fqn: this.type(enu).fqn, name: enu.name, }; } enumMember(em) { return { fqn: `${this.enum(em.enumType).fqn}.${em.name}`, name: em.name, }; } property(property) { const typeRef = this.typeReference(property.type); return { name: property.name, parentType: this.type(property.parentType), typeReference: typeRef, optional: property.optional, declaration: this.formatProperty(property.name, typeRef), }; } class(klass) { return { name: klass.name, type: this.type(klass), }; } parameter(parameter) { const typeRef = this.typeReference(parameter.type); return { name: parameter.name, parentType: this.type(parameter.parentType), typeReference: typeRef, optional: parameter.optional, variadic: parameter.variadic, declaration: this.formatProperty(parameter.name, typeRef), }; } struct(struct) { const type = this.type(struct); return { type: type, name: struct.name, import: formatImport(type), initialization: formatStructInitialization(type), }; } callable(callable) { const type = this.type(callable.parentType); const parameters = callable.parameters.sort(this.optionalityCompare); const name = callable.name; const inputs = parameters.map((p) => this.formatParameters(this.parameter(p))); const invocation = reflect.Initializer.isInitializer(callable) ? formatClassInitialization(type, inputs) : formatInvocation(type, inputs, name); let returnType; if (reflect.Initializer.isInitializer(callable)) { returnType = this.typeReference(callable.parentType.reference); } else if (reflect.Method.isMethod(callable)) { returnType = this.typeReference(callable.returns.type); } const returns = returnType === null || returnType === void 0 ? void 0 : returnType.toString({ typeFormatter: (t) => t.name, }); return { name, parentType: type, import: formatImport(type), parameters, signatures: [formatSignature(name, inputs, returns)], invocations: [invocation], returnType, }; } interface(iface) { return { name: iface.name, type: this.type(iface), }; } type(type) { const submodule = this.findSubmodule(type); const moduleLike = this.moduleLike(submodule ? submodule : type.assembly); const fqn = [moduleLike.name]; if (type.namespace) { fqn.push(type.namespace); } fqn.push(type.name); return new transpile.TranspiledType({ fqn: fqn.join('.'), name: type.name, namespace: type.namespace, module: moduleLike.name, submodule: moduleLike.submodule, submodulePath: (0, schema_1.submodulePath)(submodule), source: type, language: this.language, }); } moduleLike(moduleLike) { if (moduleLike instanceof reflect.Submodule) { const fqnParts = moduleLike.fqn.split('.'); return { name: fqnParts[0], submodule: fqnParts[1] }; } return { name: moduleLike.fqn }; } formatParameters(transpiled) { const tf = transpiled.typeReference.toString({ typeFormatter: (t) => t.name, }); if (transpiled.variadic) { return `${transpiled.name}: ${this.variadicOf(tf)}`; } return `${transpiled.name}${transpiled.optional ? '?' : ''}: ${tf}`; } formatProperty(name, typeReference) { const tf = typeReference.toString({ typeFormatter: (t) => t.name, }); return `public readonly ${name}: ${tf};`; } } exports.TypeScriptTranspile = TypeScriptTranspile; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typescript.js","sourceRoot":"","sources":["../../../src/docgen/transpile/typescript.ts"],"names":[],"mappings":"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","sourcesContent":["import * as reflect from 'jsii-reflect';\nimport * as transpile from './transpile';\nimport { submodulePath } from '../schema';\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst Case = require('case');\n\n// Helpers\nconst toCamelCase = (text?: string) => {\n  return Case.camel(text ?? '');\n};\n\nconst formatArguments = (inputs: string[]) => {\n  return inputs.join(', ');\n};\n\nconst formatStructInitialization = (type: transpile.TranspiledType) => {\n  const target = type.submodule ? `${type.namespace}.${type.name}` : type.name;\n  return `const ${toCamelCase(type.name)}: ${target} = { ... }`;\n};\n\nconst formatClassInitialization = (\n  type: transpile.TranspiledType,\n  inputs: string[],\n) => {\n  const target = type.submodule ? `${type.namespace}.${type.name}` : type.name;\n  return `new ${target}(${formatArguments(inputs)})`;\n};\n\nconst formatInvocation = (\n  type: transpile.TranspiledType,\n  inputs: string[],\n  method: string,\n) => {\n  let target = type.submodule ? `${type.namespace}.${type.name}` : type.name;\n  if (method) {\n    target = `${target}.${method}`;\n  }\n  return `${target}(${formatArguments(inputs)})`;\n};\n\nconst formatImport = (type: transpile.TranspiledType) => {\n  if (type.submodule) {\n    return `import { ${type.submodule} } from '${type.module}'`;\n  } else {\n    return `import { ${type.name} } from '${type.module}'`;\n  }\n};\n\nconst formatSignature = (name: string, inputs: string[], returns?: string) => {\n  return `public ${name}(${formatArguments(inputs)})${returns ? ': ' + returns : ''}`;\n};\n\n/**\n * A TypeScript transpiler.\n */\nexport class TypeScriptTranspile extends transpile.TranspileBase {\n  constructor() {\n    super(transpile.Language.TYPESCRIPT);\n  }\n\n  public readme(readme: string): string {\n    return readme;\n  }\n\n  public unionOf(types: string[]): string {\n    return `${types.join(' | ')}`;\n  }\n\n  public listOf(type: string): string {\n    return `${type}[]`;\n  }\n\n  public variadicOf(type: string): string {\n    return `...${this.listOf(type)}`;\n  }\n\n  public mapOf(type: string): string {\n    return `{[ key: string ]: ${type}}`;\n  }\n\n  public any(): string {\n    return 'any';\n  }\n\n  public void(): string {\n    return 'void';\n  }\n\n  public boolean(): string {\n    return 'boolean';\n  }\n\n  public str(): string {\n    return 'string';\n  }\n\n  public number(): string {\n    return 'number';\n  }\n\n  public date(): string {\n    return 'Date';\n  }\n\n  public json(): string {\n    return 'object';\n  }\n\n  public enum(enu: reflect.EnumType): transpile.TranspiledEnum {\n    return {\n      fqn: this.type(enu).fqn,\n      name: enu.name,\n    };\n  }\n\n  public enumMember(em: reflect.EnumMember): transpile.TranspiledEnumMember {\n    return {\n      fqn: `${this.enum(em.enumType).fqn}.${em.name}`,\n      name: em.name,\n    };\n  }\n\n  public property(property: reflect.Property): transpile.TranspiledProperty {\n    const typeRef = this.typeReference(property.type);\n    return {\n      name: property.name,\n      parentType: this.type(property.parentType),\n      typeReference: typeRef,\n      optional: property.optional,\n      declaration: this.formatProperty(property.name, typeRef),\n    };\n  }\n\n  public class(klass: reflect.ClassType): transpile.TranspiledClass {\n    return {\n      name: klass.name,\n      type: this.type(klass),\n    };\n  }\n\n  public parameter(\n    parameter: reflect.Parameter,\n  ): transpile.TranspiledParameter {\n    const typeRef = this.typeReference(parameter.type);\n    return {\n      name: parameter.name,\n      parentType: this.type(parameter.parentType),\n      typeReference: typeRef,\n      optional: parameter.optional,\n      variadic: parameter.variadic,\n      declaration: this.formatProperty(parameter.name, typeRef),\n    };\n  }\n\n  public struct(struct: reflect.InterfaceType): transpile.TranspiledStruct {\n    const type = this.type(struct);\n    return {\n      type: type,\n      name: struct.name,\n      import: formatImport(type),\n      initialization: formatStructInitialization(type),\n    };\n  }\n\n  public callable(callable: reflect.Callable): transpile.TranspiledCallable {\n    const type = this.type(callable.parentType);\n    const parameters = callable.parameters.sort(this.optionalityCompare);\n    const name = callable.name;\n    const inputs = parameters.map((p) => this.formatParameters(this.parameter(p)));\n\n    const invocation = reflect.Initializer.isInitializer(callable)\n      ? formatClassInitialization(type, inputs)\n      : formatInvocation(type, inputs, name);\n\n    let returnType: transpile.TranspiledTypeReference | undefined;\n    if (reflect.Initializer.isInitializer(callable)) {\n      returnType = this.typeReference(callable.parentType.reference);\n    } else if (reflect.Method.isMethod(callable)) {\n      returnType = this.typeReference(callable.returns.type);\n    }\n    const returns = returnType?.toString({\n      typeFormatter: (t) => t.name,\n    });\n\n    return {\n      name,\n      parentType: type,\n      import: formatImport(type),\n      parameters,\n      signatures: [formatSignature(name, inputs, returns)],\n      invocations: [invocation],\n      returnType,\n    };\n  }\n\n  public interface(\n    iface: reflect.InterfaceType,\n  ): transpile.TranspiledInterface {\n    return {\n      name: iface.name,\n      type: this.type(iface),\n    };\n  }\n\n  public type(type: reflect.Type): transpile.TranspiledType {\n    const submodule = this.findSubmodule(type);\n    const moduleLike = this.moduleLike(submodule ? submodule : type.assembly);\n\n    const fqn = [moduleLike.name];\n\n    if (type.namespace) {\n      fqn.push(type.namespace);\n    }\n    fqn.push(type.name);\n\n    return new transpile.TranspiledType({\n      fqn: fqn.join('.'),\n      name: type.name,\n      namespace: type.namespace,\n      module: moduleLike.name,\n      submodule: moduleLike.submodule,\n      submodulePath: submodulePath(submodule),\n      source: type,\n      language: this.language,\n    });\n  }\n\n  public moduleLike(\n    moduleLike: reflect.ModuleLike,\n  ): transpile.TranspiledModuleLike {\n    if (moduleLike instanceof reflect.Submodule) {\n      const fqnParts = moduleLike.fqn.split('.');\n      return { name: fqnParts[0], submodule: fqnParts[1] };\n    }\n    return { name: moduleLike.fqn };\n  }\n\n  private formatParameters(\n    transpiled: transpile.TranspiledParameter,\n  ): string {\n    const tf = transpiled.typeReference.toString({\n      typeFormatter: (t) => t.name,\n    });\n\n    if (transpiled.variadic) {\n      return `${transpiled.name}: ${this.variadicOf(tf)}`;\n    }\n\n    return `${transpiled.name}${transpiled.optional ? '?' : ''}: ${tf}`;\n  }\n\n  private formatProperty(\n    name: string,\n    typeReference: transpile.TranspiledTypeReference,\n  ): string {\n    const tf = typeReference.toString({\n      typeFormatter: (t) => t.name,\n    });\n    return `public readonly ${name}: ${tf};`;\n  }\n}\n"]}