Skip to content

Commit

Permalink
docs: split Operations and Functions into two different lists
Browse files Browse the repository at this point in the history
  • Loading branch information
josephjclark committed Jun 7, 2024
1 parent 7677ae0 commit c5dc4d8
Show file tree
Hide file tree
Showing 2 changed files with 83 additions and 19 deletions.
39 changes: 28 additions & 11 deletions tools/build/src/commands/docs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import fs, { writeFile, mkdir } from 'node:fs/promises';
import { existsSync } from 'node:fs';
import path from 'node:path';
import jsdoc2md from 'jsdoc-to-markdown';
import FileSet from 'file-set'
import FileSet from 'file-set';
import resolvePath from '../util/resolve-path';
import extractExports from '../util/extract-exports';

Expand All @@ -22,6 +22,19 @@ export default async (lang: string) => {
files: glob,
});

// Identify Operations
// TODO we can later add a supporting @operation tag, but this heuristic will go a long way
templateData.forEach(doclet => {
if (
doclet.returns
?.at(0)
?.type?.names.at(0)
.match(/operation/i)
) {
doclet.kind = 'operation';
}
});

// sort template data
// see: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort
templateData.sort(function (a, b) {
Expand All @@ -37,20 +50,20 @@ export default async (lang: string) => {
return 0;
});

const fileSet = new FileSet()
await fileSet.add([glob])
const fileSet = new FileSet();
await fileSet.add([glob]);

// Extract exports from common and add them to the template data as externals
for (const f of fileSet.files) {
const src = await fs.readFile(f, 'utf8')
const exports = extractExports(src).map((e) => ({
const src = await fs.readFile(f, 'utf8');
const exports = extractExports(src).map(e => ({
id: e,
common: true,
name: e,
scope: 'global',
kind: "external"
}))
templateData.push(...exports)
kind: 'external',
}));
templateData.push(...exports);
}

const helper = path.resolve('../../tools/build/src/util/hbs-helpers.js');
Expand All @@ -71,7 +84,7 @@ export default async (lang: string) => {
'example-lang': 'js',
'member-index-format': 'list',
};

console.log('rendering jsdocs...');
const docs = jsdoc2md.renderSync(renderOpts);

Expand Down Expand Up @@ -114,17 +127,21 @@ export default async (lang: string) => {
readme: `${JSON.stringify(readme)}`,
changelog: `${JSON.stringify(changelog)}`,
functions: functions.sort(),
'configuration-schema': configurationSchema
'configuration-schema': configurationSchema,
};

const destinationDir = `${root}/docs`;
const destination = `${destinationDir}/index.md`;
await mkdir(destinationDir, { recursive: true });
await writeFile(destination, docs);
await writeFile(
`${destinationDir}/raw.json`,
JSON.stringify(templateData, null, 2)
);
await writeFile(`${destinationDir}/${lang}.json`, JSON.stringify(docsJson));

console.log(`... done! `, destination);
console.log()
console.log();

return;
};
63 changes: 55 additions & 8 deletions tools/build/src/util/docs-template.hbs
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
{{#if (showMainIndex)~}}

{{#globals kind="function" ~}}
{{#if @first~}}## Functions
{{#globals kind="operation" ~}}
{{#if @first}}

#### Operations

<dl>
{{/if~}}
Expand All @@ -12,15 +14,37 @@
{{#if @prefix}}{{@prefix}} {{/if~}}
{{@accessSymbol}}{{#if (isEvent)}}"{{{name}}}"{{else}}{{{name}}}{{/if~}}
{{~#if @methodSign}}{{#if (isEvent)}} {{@methodSign}}{{else}}{{@methodSign}}{{/if}}{{/if~}}
{{{@codeClose}~}}
{{@codeClose~}}
</a>
{{~/sig}}{{/if~}}
</dt>
{{!-- <dd>{{{md (inlineLinks description)}}}</dd> --}}
{{#if @last~}}</dl>
{{/if~}}
{{/globals~}}
{{!-- {{>global-index-kinds kind="typedef" title="Typedefs" ~}} --}}

{{#globals kind="function"}}
{{#if @first}}

#### Functions

<dl>
{{/if~}}
<dt>
{{#if name}}{{#sig no-gfm=true ~}}
<a href="#{{toLowerCase (anchorName)}}">
{{~{@codeOpen}~}}
{{#if @prefix}}{{@prefix}} {{/if~}}
{{@accessSymbol}}{{#if (isEvent)}}"{{{name}}}"{{else}}{{{name}}}{{/if~}}
{{~#if @methodSign}}{{#if (isEvent)}} {{@methodSign}}{{else}}{{@methodSign}}{{/if}}{{/if~}}
{{@codeClose~}}
</a>
{{~/sig}}{{/if~}}
</dt>
{{#if @last~}}</dl>
{{/if~}}
{{/globals~}}

{{/if~}}

{{#commonFns}}
Expand All @@ -35,14 +59,37 @@ The following functions are exported from the common adaptor:
{{/if}}
{{/commonFns}}

{{#orphans ~}}
{{>separator~}}

{{#globals kind="operation" ~}}
{{#if @first~}}## Operations

Operations are used at the top level of your job code. You can nest Operations, but you cannot use an Operation within a callback.
{{/if~}}

### {{anchorName}}

{{! operations should list parameters but not returns }}
{{>sig-name}}

{{>body}}
{{>separator~}}

{{/globals~}}

{{#globals kind="function" ~}}
{{#if @first~}}

## Functions

Functions are regular Javascript functions. They are not state aware, they do not neccessarily take state and they usually don't return state. Functions can only be used inside callback functions.
{{/if~}}

### {{anchorName}}

{{>sig-name}}

{{>body}}
{{>member-index~}}
{{>separator~}}
{{>members~}}
{{/orphans~}}

{{/globals~}}

0 comments on commit c5dc4d8

Please sign in to comment.