UNPKG

jsii-docgen

Version:

generates api docs for jsii modules

46 lines 18.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CURRENT_SCHEMA_VERSION = void 0; exports.extractDocs = extractDocs; exports.submodulePath = submodulePath; exports.filterUndefined = filterUndefined; exports.CURRENT_SCHEMA_VERSION = '0.1'; function extractDocs(docs) { const links = []; const see = docs.docs.see; // @see if (see && see.length > 0) { links.push(see); } const link = docs.customTag('link'); // @link if (link && link.length > 0) { links.push(link); } return filterUndefined({ // ignore defaults and empty strings to save space summary: docs.summary.length > 0 ? docs.summary : undefined, remarks: docs.remarks.length > 0 ? docs.remarks : undefined, example: docs.example.length > 0 ? docs.example : undefined, links: links.length > 0 ? links : undefined, deprecated: docs.deprecated === true ? true : undefined, deprecationReason: docs.deprecationReason, }); } /** * Generates the name of the submodule. */ function submodulePath(module) { if (!module) return undefined; const path = module.fqn.split('.').splice(1).join('.'); return path.length > 0 ? path : undefined; } function filterUndefined(obj) { const ret = {}; for (const [k, v] of Object.entries(obj)) { if (v !== undefined) { ret[k] = v; } } return ret; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../src/docgen/schema.ts"],"names":[],"mappings":";;;AAifA,kCAmBC;AAKD,sCAIC;AAED,0CAQC;AArhBY,QAAA,sBAAsB,GAAG,KAAK,CAAC;AA+e5C,SAAgB,WAAW,CAAC,IAAkB;IAC5C,MAAM,KAAK,GAAG,EAAE,CAAC;IACjB,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO;IAClC,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC1B,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAClB,CAAC;IACD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ;IAC7C,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC5B,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnB,CAAC;IACD,OAAO,eAAe,CAAC;QACrB,kDAAkD;QAClD,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;QAC3D,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;QAC3D,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;QAC3D,KAAK,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;QAC3C,UAAU,EAAE,IAAI,CAAC,UAAU,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS;QACvD,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;KAC1C,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAgB,aAAa,CAAC,MAA0B;IACtD,IAAI,CAAC,MAAM;QAAE,OAAO,SAAS,CAAC;IAC9B,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACvD,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;AAC5C,CAAC;AAED,SAAgB,eAAe,CAAmB,GAAM;IACtD,MAAM,GAAG,GAAQ,EAAE,CAAC;IACpB,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;QACzC,IAAI,CAAC,KAAK,SAAS,EAAE,CAAC;YACpB,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACb,CAAC;IACH,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC","sourcesContent":["import * as reflect from 'jsii-reflect';\n\nexport const CURRENT_SCHEMA_VERSION = '0.1';\n\n/**\n * Describes any kind of type. This could be a primitive, a user-defined type\n * (like `Bucket`), or a composition of types (like `Map<string, Bucket>[]`).\n */\nexport interface TypeSchema {\n  /**\n   * The language-specific name of the type. May contain \"%\" placeholder\n   * values to indicate references to types defined in the \"types\" field.\n   *\n   * @example \"string\"\n   * @example \"%\"\n   * @example \"typing.List[%]\"\n   * @example \"Map<%, %>\"\n   */\n  readonly formattingPattern: string;\n\n  /**\n   * Types referenced within the \"name\" field. The order of these corresponds\n   * to the order of the %'s in `formattingPattern`.\n   */\n  readonly types?: (TypeSchema | JsiiEntity)[];\n}\n\n/**\n * Describes a single \"entity\" in the jsii type system. This may be a type,\n * but it could also be a property, method, parameter, enum member, etc.\n */\nexport interface JsiiEntity extends AssemblyMetadataSchema {\n  /**\n   * An id that uniquely identifies this type among all entities in the\n   * document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the entity.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific type FQN.\n   */\n  readonly fqn: string;\n}\n\n/**\n * Describes a property.\n */\nexport interface PropertySchema extends Usage, Optional, Documentable {\n  /**\n   * An id that uniquely identifies this property among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the property.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n\n  /**\n   * The type of the property.\n   */\n  readonly type: TypeSchema;\n\n  /**\n   * Whether the property is a constant.\n   * @default false\n   */\n  readonly const?: boolean;\n}\n\n/**\n * Describes a parameter.\n */\nexport interface ParameterSchema extends Optional, Documentable {\n  /**\n   * An id that uniquely identifies this parameter among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the parameter.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n\n  /**\n   * The type of the parameter.\n   */\n  readonly type: TypeSchema;\n\n  /**\n   * Whether the parameter is variadic.\n   */\n  readonly variadic: boolean;\n}\n\n/**\n * Common properties of a callable.\n */\nexport interface CallableSchema extends Usage {\n  /**\n   * An id that uniquely identifies this callable among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the callable.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n\n  /**\n   * Parameters of the callable.\n   */\n  readonly parameters: ParameterSchema[];\n}\n\n/**\n * Describes a constructor.\n */\nexport interface InitializerSchema extends CallableSchema {}\n\n/**\n * Describes a method.\n */\nexport interface MethodSchema extends CallableSchema, Documentable {}\n\n/**\n * Describes a class.\n */\nexport interface ClassSchema extends Documentable {\n  /**\n   * An id that uniquely identifies this class among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the class.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n\n  /**\n   * Interfaces this class implements.\n   */\n  readonly interfaces: JsiiEntity[];\n\n  /**\n   * Class initializer.\n   */\n  readonly initializer?: InitializerSchema;\n\n  /**\n   * Instance methods.\n   */\n  readonly instanceMethods: MethodSchema[];\n\n  /**\n   * Static methods.\n   */\n  readonly staticMethods: MethodSchema[];\n\n  /**\n   * Properties.\n   */\n  readonly properties: PropertySchema[];\n\n  /**\n   * Constants.\n   */\n  readonly constants: PropertySchema[];\n}\n\n/**\n * Describes a construct.\n */\nexport interface ConstructSchema extends ClassSchema {}\n\n/**\n * Describes a struct.\n */\nexport interface StructSchema extends Usage, Documentable {\n  /**\n   * An id that uniquely identifies this struct among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the struct.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n\n  /**\n   * Properties.\n   */\n  readonly properties: PropertySchema[];\n}\n\n/**\n * Describes a behavioral interface, also sometimes known as a protocol.\n */\nexport interface InterfaceSchema extends Documentable {\n  /**\n   * An id that uniquely identifies this interface among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the interface.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n\n  /**\n   * Interfaces that this interface extends.\n   */\n  readonly interfaces: JsiiEntity[];\n\n  /**\n   * Types implementing this interface.\n   */\n  readonly implementations: JsiiEntity[];\n\n  /**\n   * Methods.\n   */\n  readonly instanceMethods: MethodSchema[];\n\n  /**\n   * Properties.\n   */\n  readonly properties: PropertySchema[];\n}\n\n/**\n * Describes an enum member.\n */\nexport interface EnumMemberSchema extends Documentable {\n  /**\n   * An id that uniquely identifies this enum member among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the enum member.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n}\n\n/**\n * Describes an enum.\n */\nexport interface EnumSchema extends Documentable {\n  /**\n   * An id that uniquely identifies this enum among all entities in\n   * the document and is same across languages.\n   */\n  readonly id: string;\n\n  /**\n   * The friendly language-specific name for the enum.\n   */\n  readonly displayName: string;\n\n  /**\n   * The language-specific fqn.\n   */\n  readonly fqn: string;\n\n  /**\n   * Enum members.\n   */\n  readonly members: EnumMemberSchema[];\n}\n\n/**\n * Describes the API Reference.\n */\nexport interface ApiReferenceSchema {\n\n  /**\n   * Constructs.\n   */\n  readonly constructs: ConstructSchema[];\n\n  /**\n   * Classes.\n   */\n  readonly classes: ClassSchema[];\n\n  /**\n   * Structs.\n   */\n  readonly structs: StructSchema[];\n\n  /**\n   * Interfaces.\n   */\n  readonly interfaces: InterfaceSchema[];\n\n  /**\n   * Enums.\n   */\n  readonly enums: EnumSchema[];\n}\n\n/**\n * Metadata about a particular jsii assembly.\n */\nexport interface AssemblyMetadataSchema {\n  /**\n   * Name of the jsii assembly/package.\n   */\n  readonly packageName: string;\n\n  /**\n   * Version of the jsii assembly/package.\n   */\n  readonly packageVersion: string;\n\n  /**\n   * Language-independent name of the jsii submodule.\n   * if undefined, it is implicitly the root module.\n   *\n   * @example `aws_sqs`\n   */\n  readonly submodule?: string;\n}\n\n/**\n * Describes the top-level schema.\n */\nexport interface Schema {\n  /**\n   * Schema version number.\n   */\n  readonly version: string;\n\n  /**\n   * Language that the documentation has been transliterated to.\n   */\n  readonly language: string;\n\n  /**\n   * Whether this document represents documentation for all submodules\n   * (including the root).\n   *\n   * @default false\n   */\n  readonly allSubmodules?: boolean;\n\n  /**\n   * Assembly metadata.\n   */\n  readonly metadata: AssemblyMetadataSchema;\n\n  /**\n   * Readme.\n   */\n  readonly readme?: string;\n\n  /**\n   * API Reference.\n   */\n  readonly apiReference?: ApiReferenceSchema;\n}\n\n\n//\n// SHARED INTERFACES\n//\n\n/**\n * An entity that can have a doc string.\n */\nexport interface Documentable {\n  /**\n   * Doc string.\n   */\n  readonly docs: DocsSchema;\n}\n\n/**\n * Docstring information.\n *\n * @see jsii.Docs\n */\nexport interface DocsSchema {\n  /**\n   * Summary documentation for an API item.\n   *\n   * The first part of the documentation before hitting a `@remarks` tags, or\n   * the first line of the doc comment block if there is no `@remarks` tag.\n   */\n  readonly summary?: string;\n\n  /**\n   * Detailed information about an API item.\n   *\n   * Either the explicitly tagged `@remarks` section, otherwise everything\n   * past the first paragraph if there is no `@remarks` tag.\n   */\n  readonly remarks?: string;\n\n  /**\n   * `@see` and `@link` links with more information.\n   */\n  readonly links?: string[];\n\n  /**\n   * Code snippet showing example usage of an API item, that has been provided\n   * by the construct library authors.\n   */\n  readonly example?: string;\n\n  /**\n   * Whether or not it is deprecated.\n   */\n  readonly deprecated?: boolean;\n\n  /**\n   * Deprecation reason (if applicable).\n   */\n  readonly deprecationReason?: string;\n}\n\n/**\n * An entity that may include a code snippet showing how to use it.\n */\nexport interface Usage {\n  /**\n   * Code snippet.\n   * @default - none\n   */\n  readonly usage?: string;\n}\n\n/**\n * An entity that may be optional.\n */\nexport interface Optional {\n  /**\n   * Whether or not it is optional.\n   * @default false\n   */\n  readonly optional?: boolean;\n\n  /**\n   * The default value, if applicable.\n   * @default - none\n   */\n  readonly default?: string;\n}\n\nexport function extractDocs(docs: reflect.Docs): DocsSchema {\n  const links = [];\n  const see = docs.docs.see; // @see\n  if (see && see.length > 0) {\n    links.push(see);\n  }\n  const link = docs.customTag('link'); // @link\n  if (link && link.length > 0) {\n    links.push(link);\n  }\n  return filterUndefined({\n    // ignore defaults and empty strings to save space\n    summary: docs.summary.length > 0 ? docs.summary : undefined,\n    remarks: docs.remarks.length > 0 ? docs.remarks : undefined,\n    example: docs.example.length > 0 ? docs.example : undefined,\n    links: links.length > 0 ? links : undefined,\n    deprecated: docs.deprecated === true ? true : undefined,\n    deprecationReason: docs.deprecationReason,\n  });\n}\n\n/**\n * Generates the name of the submodule.\n */\nexport function submodulePath(module?: reflect.Submodule): string | undefined {\n  if (!module) return undefined;\n  const path = module.fqn.split('.').splice(1).join('.');\n  return path.length > 0 ? path : undefined;\n}\n\nexport function filterUndefined<T extends object>(obj: T): T {\n  const ret: any = {};\n  for (const [k, v] of Object.entries(obj)) {\n    if (v !== undefined) {\n      ret[k] = v;\n    }\n  }\n  return ret;\n}\n"]}