@kubb/parser-md 5.0.0-beta.62 → 5.0.0-beta.64
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/dist/index.cjs +5 -12
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +3 -3
- package/dist/index.js +6 -13
- package/dist/index.js.map +1 -1
- package/package.json +3 -4
- package/src/index.ts +0 -1
- package/src/parserMd.ts +0 -59
- package/src/utils.ts +0 -45
- /package/dist/{chunk-C0LytTxp.js → rolldown-runtime-C0LytTxp.js} +0 -0
package/dist/index.cjs
CHANGED
|
@@ -5,24 +5,17 @@ let _kubb_ast_utils = require("@kubb/ast/utils");
|
|
|
5
5
|
let yaml = require("yaml");
|
|
6
6
|
//#region src/utils.ts
|
|
7
7
|
/**
|
|
8
|
-
* Wraps a plain object as a YAML frontmatter envelope
|
|
9
|
-
*
|
|
10
|
-
* ```
|
|
11
|
-
* ---
|
|
12
|
-
* <yaml>
|
|
13
|
-
* ---
|
|
14
|
-
* ```
|
|
15
|
-
*
|
|
8
|
+
* Wraps a plain object as a YAML frontmatter envelope (`---\n<yaml>\n---`).
|
|
16
9
|
* Returns an empty string for `null`, `undefined`, or empty objects so callers
|
|
17
|
-
* can drop the result through the same filter chain as
|
|
10
|
+
* can drop the result through the same filter chain as other optional fields.
|
|
18
11
|
*/
|
|
19
|
-
function
|
|
12
|
+
function stringifyFrontmatter(data) {
|
|
20
13
|
if (!data || Object.keys(data).length === 0) return "";
|
|
21
14
|
return `---\n${(0, yaml.stringify)(data).trimEnd()}\n---`;
|
|
22
15
|
}
|
|
23
16
|
/**
|
|
24
17
|
* Joins a list of markdown fragments with blank lines. Plain objects are
|
|
25
|
-
* rendered as YAML frontmatter via {@link
|
|
18
|
+
* rendered as YAML frontmatter via {@link stringifyFrontmatter}, and strings pass
|
|
26
19
|
* through unchanged.
|
|
27
20
|
*
|
|
28
21
|
* @example
|
|
@@ -35,7 +28,7 @@ function print(...parts) {
|
|
|
35
28
|
const rendered = [];
|
|
36
29
|
for (const part of parts) {
|
|
37
30
|
if (part === null || part === void 0 || part === "") continue;
|
|
38
|
-
const text = typeof part === "string" ? part :
|
|
31
|
+
const text = typeof part === "string" ? part : stringifyFrontmatter(part);
|
|
39
32
|
if (text) rendered.push(text.trimEnd());
|
|
40
33
|
}
|
|
41
34
|
return rendered.join("\n\n");
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","names":[],"sources":["../src/utils.ts","../src/parserMd.ts"],"sourcesContent":["import { stringify } from 'yaml'\n\n/**\n * Markdown `print` input, either a markdown text fragment (passed through\n * verbatim) or a plain object that is serialized as a YAML frontmatter envelope.\n */\nexport type PrintInput = string | Record<string, unknown>\n\n/**\n * Wraps a plain object as a YAML frontmatter envelope
|
|
1
|
+
{"version":3,"file":"index.cjs","names":[],"sources":["../src/utils.ts","../src/parserMd.ts"],"sourcesContent":["import { stringify } from 'yaml'\n\n/**\n * Markdown `print` input, either a markdown text fragment (passed through\n * verbatim) or a plain object that is serialized as a YAML frontmatter envelope.\n */\nexport type PrintInput = string | Record<string, unknown>\n\n/**\n * Wraps a plain object as a YAML frontmatter envelope (`---\\n<yaml>\\n---`).\n * Returns an empty string for `null`, `undefined`, or empty objects so callers\n * can drop the result through the same filter chain as other optional fields.\n */\nexport function stringifyFrontmatter(data: Record<string, unknown> | null | undefined): string {\n if (!data || Object.keys(data).length === 0) return ''\n return `---\\n${stringify(data).trimEnd()}\\n---`\n}\n\n/**\n * Joins a list of markdown fragments with blank lines. Plain objects are\n * rendered as YAML frontmatter via {@link stringifyFrontmatter}, and strings pass\n * through unchanged.\n *\n * @example\n * ```ts\n * print({ title: 'Hi' }, '# Hello')\n * // '---\\ntitle: Hi\\n---\\n\\n# Hello'\n * ```\n */\nexport function print(...parts: Array<PrintInput | null | undefined>): string {\n const rendered: Array<string> = []\n for (const part of parts) {\n if (part === null || part === undefined || part === '') continue\n const text = typeof part === 'string' ? part : stringifyFrontmatter(part)\n if (text) rendered.push(text.trimEnd())\n }\n return rendered.join('\\n\\n')\n}\n","import type { ast } from '@kubb/core'\nimport { defineParser } from '@kubb/core'\nimport { extractStringsFromNodes } from '@kubb/ast/utils'\n\nimport { print, type PrintInput } from './utils.ts'\n\n/**\n * Metadata accepted by `parserMd`. Set `frontmatter` on a `<File meta={...}>` and\n * the parser prepends those keys as a YAML frontmatter envelope.\n */\nexport type MdMeta = {\n frontmatter?: Record<string, unknown> | null\n}\n\n/**\n * Kubb parser for `.md` and `.markdown` files. Joins source blocks as plain\n * markdown (separated by blank lines) and, when `file.meta.frontmatter` is set,\n * prepends a YAML frontmatter envelope produced by `parserMd.print`.\n *\n * Add to the `parsers` array on `defineConfig` to opt in. `parserTs` keeps\n * handling `.ts`/`.js` files, `parserMd` claims `.md`/`.markdown`.\n *\n * @example\n * ```ts\n * import { defineConfig } from 'kubb'\n * import { adapterOas } from '@kubb/adapter-oas'\n * import { parserMd } from '@kubb/parser-md'\n *\n * export default defineConfig({\n * input: { path: './petStore.yaml' },\n * output: { path: './src/gen' },\n * adapter: adapterOas(),\n * parsers: [parserMd],\n * plugins: [],\n * })\n * ```\n */\nexport const parserMd = defineParser({\n name: 'markdown',\n extNames: ['.md', '.markdown'],\n print(...parts: Array<PrintInput>) {\n return print(...parts)\n },\n parse(file) {\n const sourceParts: Array<string> = []\n for (const source of file.sources) {\n const text = extractStringsFromNodes(source.nodes as Array<ast.CodeNode>)\n if (text) sourceParts.push(text.trimEnd())\n }\n const body = sourceParts.join('\\n\\n')\n\n const meta = file.meta as MdMeta | undefined\n const frontmatter = print(meta?.frontmatter ?? undefined)\n\n const parts = [file.banner, frontmatter, body, file.footer].filter((segment): segment is string => Boolean(segment)).map((segment) => segment.trimEnd())\n\n return parts.join('\\n\\n')\n },\n})\n"],"mappings":";;;;;;;;;;;AAaA,SAAgB,qBAAqB,MAA0D;CAC7F,IAAI,CAAC,QAAQ,OAAO,KAAK,IAAI,CAAC,CAAC,WAAW,GAAG,OAAO;CACpD,OAAO,SAAA,GAAA,KAAA,UAAA,CAAkB,IAAI,CAAC,CAAC,QAAQ,EAAE;AAC3C;;;;;;;;;;;;AAaA,SAAgB,MAAM,GAAG,OAAqD;CAC5E,MAAM,WAA0B,CAAC;CACjC,KAAK,MAAM,QAAQ,OAAO;EACxB,IAAI,SAAS,QAAQ,SAAS,KAAA,KAAa,SAAS,IAAI;EACxD,MAAM,OAAO,OAAO,SAAS,WAAW,OAAO,qBAAqB,IAAI;EACxE,IAAI,MAAM,SAAS,KAAK,KAAK,QAAQ,CAAC;CACxC;CACA,OAAO,SAAS,KAAK,MAAM;AAC7B;;;;;;;;;;;;;;;;;;;;;;;;;;ACAA,MAAa,YAAA,GAAA,WAAA,aAAA,CAAwB;CACnC,MAAM;CACN,UAAU,CAAC,OAAO,WAAW;CAC7B,MAAM,GAAG,OAA0B;EACjC,OAAO,MAAM,GAAG,KAAK;CACvB;CACA,MAAM,MAAM;EACV,MAAM,cAA6B,CAAC;EACpC,KAAK,MAAM,UAAU,KAAK,SAAS;GACjC,MAAM,QAAA,GAAA,gBAAA,wBAAA,CAA+B,OAAO,KAA4B;GACxE,IAAI,MAAM,YAAY,KAAK,KAAK,QAAQ,CAAC;EAC3C;EACA,MAAM,OAAO,YAAY,KAAK,MAAM;EAEpC,MAAM,OAAO,KAAK;EAClB,MAAM,cAAc,MAAM,MAAM,eAAe,KAAA,CAAS;EAIxD,OAFc;GAAC,KAAK;GAAQ;GAAa;GAAM,KAAK;EAAM,CAAC,CAAC,QAAQ,YAA+B,QAAQ,OAAO,CAAC,CAAC,CAAC,KAAK,YAAY,QAAQ,QAAQ,CAE3I,CAAC,CAAC,KAAK,MAAM;CAC1B;AACF,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as __name } from "./
|
|
1
|
+
import { t as __name } from "./rolldown-runtime-C0LytTxp.js";
|
|
2
2
|
import { ast } from "@kubb/core";
|
|
3
3
|
|
|
4
4
|
//#region src/utils.d.ts
|
|
@@ -10,8 +10,8 @@ type PrintInput = string | Record<string, unknown>;
|
|
|
10
10
|
//#endregion
|
|
11
11
|
//#region src/parserMd.d.ts
|
|
12
12
|
/**
|
|
13
|
-
* Metadata accepted by `parserMd`. Set `frontmatter` on a `<File meta={
|
|
14
|
-
*
|
|
13
|
+
* Metadata accepted by `parserMd`. Set `frontmatter` on a `<File meta={...}>` and
|
|
14
|
+
* the parser prepends those keys as a YAML frontmatter envelope.
|
|
15
15
|
*/
|
|
16
16
|
type MdMeta = {
|
|
17
17
|
frontmatter?: Record<string, unknown> | null;
|
package/dist/index.js
CHANGED
|
@@ -1,27 +1,20 @@
|
|
|
1
|
-
import "./
|
|
1
|
+
import "./rolldown-runtime-C0LytTxp.js";
|
|
2
2
|
import { defineParser } from "@kubb/core";
|
|
3
3
|
import { extractStringsFromNodes } from "@kubb/ast/utils";
|
|
4
4
|
import { stringify } from "yaml";
|
|
5
5
|
//#region src/utils.ts
|
|
6
6
|
/**
|
|
7
|
-
* Wraps a plain object as a YAML frontmatter envelope
|
|
8
|
-
*
|
|
9
|
-
* ```
|
|
10
|
-
* ---
|
|
11
|
-
* <yaml>
|
|
12
|
-
* ---
|
|
13
|
-
* ```
|
|
14
|
-
*
|
|
7
|
+
* Wraps a plain object as a YAML frontmatter envelope (`---\n<yaml>\n---`).
|
|
15
8
|
* Returns an empty string for `null`, `undefined`, or empty objects so callers
|
|
16
|
-
* can drop the result through the same filter chain as
|
|
9
|
+
* can drop the result through the same filter chain as other optional fields.
|
|
17
10
|
*/
|
|
18
|
-
function
|
|
11
|
+
function stringifyFrontmatter(data) {
|
|
19
12
|
if (!data || Object.keys(data).length === 0) return "";
|
|
20
13
|
return `---\n${stringify(data).trimEnd()}\n---`;
|
|
21
14
|
}
|
|
22
15
|
/**
|
|
23
16
|
* Joins a list of markdown fragments with blank lines. Plain objects are
|
|
24
|
-
* rendered as YAML frontmatter via {@link
|
|
17
|
+
* rendered as YAML frontmatter via {@link stringifyFrontmatter}, and strings pass
|
|
25
18
|
* through unchanged.
|
|
26
19
|
*
|
|
27
20
|
* @example
|
|
@@ -34,7 +27,7 @@ function print(...parts) {
|
|
|
34
27
|
const rendered = [];
|
|
35
28
|
for (const part of parts) {
|
|
36
29
|
if (part === null || part === void 0 || part === "") continue;
|
|
37
|
-
const text = typeof part === "string" ? part :
|
|
30
|
+
const text = typeof part === "string" ? part : stringifyFrontmatter(part);
|
|
38
31
|
if (text) rendered.push(text.trimEnd());
|
|
39
32
|
}
|
|
40
33
|
return rendered.join("\n\n");
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../src/utils.ts","../src/parserMd.ts"],"sourcesContent":["import { stringify } from 'yaml'\n\n/**\n * Markdown `print` input, either a markdown text fragment (passed through\n * verbatim) or a plain object that is serialized as a YAML frontmatter envelope.\n */\nexport type PrintInput = string | Record<string, unknown>\n\n/**\n * Wraps a plain object as a YAML frontmatter envelope
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../src/utils.ts","../src/parserMd.ts"],"sourcesContent":["import { stringify } from 'yaml'\n\n/**\n * Markdown `print` input, either a markdown text fragment (passed through\n * verbatim) or a plain object that is serialized as a YAML frontmatter envelope.\n */\nexport type PrintInput = string | Record<string, unknown>\n\n/**\n * Wraps a plain object as a YAML frontmatter envelope (`---\\n<yaml>\\n---`).\n * Returns an empty string for `null`, `undefined`, or empty objects so callers\n * can drop the result through the same filter chain as other optional fields.\n */\nexport function stringifyFrontmatter(data: Record<string, unknown> | null | undefined): string {\n if (!data || Object.keys(data).length === 0) return ''\n return `---\\n${stringify(data).trimEnd()}\\n---`\n}\n\n/**\n * Joins a list of markdown fragments with blank lines. Plain objects are\n * rendered as YAML frontmatter via {@link stringifyFrontmatter}, and strings pass\n * through unchanged.\n *\n * @example\n * ```ts\n * print({ title: 'Hi' }, '# Hello')\n * // '---\\ntitle: Hi\\n---\\n\\n# Hello'\n * ```\n */\nexport function print(...parts: Array<PrintInput | null | undefined>): string {\n const rendered: Array<string> = []\n for (const part of parts) {\n if (part === null || part === undefined || part === '') continue\n const text = typeof part === 'string' ? part : stringifyFrontmatter(part)\n if (text) rendered.push(text.trimEnd())\n }\n return rendered.join('\\n\\n')\n}\n","import type { ast } from '@kubb/core'\nimport { defineParser } from '@kubb/core'\nimport { extractStringsFromNodes } from '@kubb/ast/utils'\n\nimport { print, type PrintInput } from './utils.ts'\n\n/**\n * Metadata accepted by `parserMd`. Set `frontmatter` on a `<File meta={...}>` and\n * the parser prepends those keys as a YAML frontmatter envelope.\n */\nexport type MdMeta = {\n frontmatter?: Record<string, unknown> | null\n}\n\n/**\n * Kubb parser for `.md` and `.markdown` files. Joins source blocks as plain\n * markdown (separated by blank lines) and, when `file.meta.frontmatter` is set,\n * prepends a YAML frontmatter envelope produced by `parserMd.print`.\n *\n * Add to the `parsers` array on `defineConfig` to opt in. `parserTs` keeps\n * handling `.ts`/`.js` files, `parserMd` claims `.md`/`.markdown`.\n *\n * @example\n * ```ts\n * import { defineConfig } from 'kubb'\n * import { adapterOas } from '@kubb/adapter-oas'\n * import { parserMd } from '@kubb/parser-md'\n *\n * export default defineConfig({\n * input: { path: './petStore.yaml' },\n * output: { path: './src/gen' },\n * adapter: adapterOas(),\n * parsers: [parserMd],\n * plugins: [],\n * })\n * ```\n */\nexport const parserMd = defineParser({\n name: 'markdown',\n extNames: ['.md', '.markdown'],\n print(...parts: Array<PrintInput>) {\n return print(...parts)\n },\n parse(file) {\n const sourceParts: Array<string> = []\n for (const source of file.sources) {\n const text = extractStringsFromNodes(source.nodes as Array<ast.CodeNode>)\n if (text) sourceParts.push(text.trimEnd())\n }\n const body = sourceParts.join('\\n\\n')\n\n const meta = file.meta as MdMeta | undefined\n const frontmatter = print(meta?.frontmatter ?? undefined)\n\n const parts = [file.banner, frontmatter, body, file.footer].filter((segment): segment is string => Boolean(segment)).map((segment) => segment.trimEnd())\n\n return parts.join('\\n\\n')\n },\n})\n"],"mappings":";;;;;;;;;;AAaA,SAAgB,qBAAqB,MAA0D;CAC7F,IAAI,CAAC,QAAQ,OAAO,KAAK,IAAI,CAAC,CAAC,WAAW,GAAG,OAAO;CACpD,OAAO,QAAQ,UAAU,IAAI,CAAC,CAAC,QAAQ,EAAE;AAC3C;;;;;;;;;;;;AAaA,SAAgB,MAAM,GAAG,OAAqD;CAC5E,MAAM,WAA0B,CAAC;CACjC,KAAK,MAAM,QAAQ,OAAO;EACxB,IAAI,SAAS,QAAQ,SAAS,KAAA,KAAa,SAAS,IAAI;EACxD,MAAM,OAAO,OAAO,SAAS,WAAW,OAAO,qBAAqB,IAAI;EACxE,IAAI,MAAM,SAAS,KAAK,KAAK,QAAQ,CAAC;CACxC;CACA,OAAO,SAAS,KAAK,MAAM;AAC7B;;;;;;;;;;;;;;;;;;;;;;;;;;ACAA,MAAa,WAAW,aAAa;CACnC,MAAM;CACN,UAAU,CAAC,OAAO,WAAW;CAC7B,MAAM,GAAG,OAA0B;EACjC,OAAO,MAAM,GAAG,KAAK;CACvB;CACA,MAAM,MAAM;EACV,MAAM,cAA6B,CAAC;EACpC,KAAK,MAAM,UAAU,KAAK,SAAS;GACjC,MAAM,OAAO,wBAAwB,OAAO,KAA4B;GACxE,IAAI,MAAM,YAAY,KAAK,KAAK,QAAQ,CAAC;EAC3C;EACA,MAAM,OAAO,YAAY,KAAK,MAAM;EAEpC,MAAM,OAAO,KAAK;EAClB,MAAM,cAAc,MAAM,MAAM,eAAe,KAAA,CAAS;EAIxD,OAFc;GAAC,KAAK;GAAQ;GAAa;GAAM,KAAK;EAAM,CAAC,CAAC,QAAQ,YAA+B,QAAQ,OAAO,CAAC,CAAC,CAAC,KAAK,YAAY,QAAQ,QAAQ,CAE3I,CAAC,CAAC,KAAK,MAAM;CAC1B;AACF,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kubb/parser-md",
|
|
3
|
-
"version": "5.0.0-beta.
|
|
3
|
+
"version": "5.0.0-beta.64",
|
|
4
4
|
"description": "Markdown source file parser for Kubb. Converts the universal AST to `.md` source and renders YAML frontmatter via the `print` helper.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"codegen",
|
|
@@ -18,7 +18,6 @@
|
|
|
18
18
|
"directory": "packages/parser-md"
|
|
19
19
|
},
|
|
20
20
|
"files": [
|
|
21
|
-
"src",
|
|
22
21
|
"dist",
|
|
23
22
|
"!/**/**.test.**",
|
|
24
23
|
"!/**/__tests__/**",
|
|
@@ -42,8 +41,8 @@
|
|
|
42
41
|
},
|
|
43
42
|
"dependencies": {
|
|
44
43
|
"yaml": "^2.9.0",
|
|
45
|
-
"@kubb/ast": "5.0.0-beta.
|
|
46
|
-
"@kubb/core": "5.0.0-beta.
|
|
44
|
+
"@kubb/ast": "5.0.0-beta.64",
|
|
45
|
+
"@kubb/core": "5.0.0-beta.64"
|
|
47
46
|
},
|
|
48
47
|
"devDependencies": {
|
|
49
48
|
"@internals/utils": "0.0.0"
|
package/src/index.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { parserMd, type MdMeta } from './parserMd.ts'
|
package/src/parserMd.ts
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import type { ast } from '@kubb/core'
|
|
2
|
-
import { defineParser } from '@kubb/core'
|
|
3
|
-
import { extractStringsFromNodes } from '@kubb/ast/utils'
|
|
4
|
-
|
|
5
|
-
import { print, type PrintInput } from './utils.ts'
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Metadata accepted by `parserMd`. Set `frontmatter` on a `<File meta={…}>` to
|
|
9
|
-
* have the parser prepend the corresponding YAML envelope.
|
|
10
|
-
*/
|
|
11
|
-
export type MdMeta = {
|
|
12
|
-
frontmatter?: Record<string, unknown> | null
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Kubb parser for `.md` and `.markdown` files. Joins source blocks as plain
|
|
17
|
-
* markdown (separated by blank lines) and, when `file.meta.frontmatter` is set,
|
|
18
|
-
* prepends a YAML frontmatter envelope produced by `parserMd.print`.
|
|
19
|
-
*
|
|
20
|
-
* Add to the `parsers` array on `defineConfig` to opt in. `parserTs` keeps
|
|
21
|
-
* handling `.ts`/`.js` files, `parserMd` claims `.md`/`.markdown`.
|
|
22
|
-
*
|
|
23
|
-
* @example
|
|
24
|
-
* ```ts
|
|
25
|
-
* import { defineConfig } from 'kubb'
|
|
26
|
-
* import { adapterOas } from '@kubb/adapter-oas'
|
|
27
|
-
* import { parserMd } from '@kubb/parser-md'
|
|
28
|
-
*
|
|
29
|
-
* export default defineConfig({
|
|
30
|
-
* input: { path: './petStore.yaml' },
|
|
31
|
-
* output: { path: './src/gen' },
|
|
32
|
-
* adapter: adapterOas(),
|
|
33
|
-
* parsers: [parserMd],
|
|
34
|
-
* plugins: [],
|
|
35
|
-
* })
|
|
36
|
-
* ```
|
|
37
|
-
*/
|
|
38
|
-
export const parserMd = defineParser({
|
|
39
|
-
name: 'markdown',
|
|
40
|
-
extNames: ['.md', '.markdown'],
|
|
41
|
-
print(...parts: Array<PrintInput>) {
|
|
42
|
-
return print(...parts)
|
|
43
|
-
},
|
|
44
|
-
parse(file) {
|
|
45
|
-
const sourceParts: Array<string> = []
|
|
46
|
-
for (const source of file.sources) {
|
|
47
|
-
const text = extractStringsFromNodes(source.nodes as Array<ast.CodeNode>)
|
|
48
|
-
if (text) sourceParts.push(text.trimEnd())
|
|
49
|
-
}
|
|
50
|
-
const body = sourceParts.join('\n\n')
|
|
51
|
-
|
|
52
|
-
const meta = file.meta as MdMeta | undefined
|
|
53
|
-
const frontmatter = print(meta?.frontmatter ?? undefined)
|
|
54
|
-
|
|
55
|
-
const parts = [file.banner, frontmatter, body, file.footer].filter((segment): segment is string => Boolean(segment)).map((segment) => segment.trimEnd())
|
|
56
|
-
|
|
57
|
-
return parts.join('\n\n')
|
|
58
|
-
},
|
|
59
|
-
})
|
package/src/utils.ts
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { stringify } from 'yaml'
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Markdown `print` input, either a markdown text fragment (passed through
|
|
5
|
-
* verbatim) or a plain object that is serialized as a YAML frontmatter envelope.
|
|
6
|
-
*/
|
|
7
|
-
export type PrintInput = string | Record<string, unknown>
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Wraps a plain object as a YAML frontmatter envelope:
|
|
11
|
-
*
|
|
12
|
-
* ```
|
|
13
|
-
* ---
|
|
14
|
-
* <yaml>
|
|
15
|
-
* ---
|
|
16
|
-
* ```
|
|
17
|
-
*
|
|
18
|
-
* Returns an empty string for `null`, `undefined`, or empty objects so callers
|
|
19
|
-
* can drop the result through the same filter chain as banner/footer fields.
|
|
20
|
-
*/
|
|
21
|
-
function printFrontmatter(data: Record<string, unknown> | null | undefined): string {
|
|
22
|
-
if (!data || Object.keys(data).length === 0) return ''
|
|
23
|
-
return `---\n${stringify(data).trimEnd()}\n---`
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Joins a list of markdown fragments with blank lines. Plain objects are
|
|
28
|
-
* rendered as YAML frontmatter via {@link printFrontmatter}, and strings pass
|
|
29
|
-
* through unchanged.
|
|
30
|
-
*
|
|
31
|
-
* @example
|
|
32
|
-
* ```ts
|
|
33
|
-
* print({ title: 'Hi' }, '# Hello')
|
|
34
|
-
* // '---\ntitle: Hi\n---\n\n# Hello'
|
|
35
|
-
* ```
|
|
36
|
-
*/
|
|
37
|
-
export function print(...parts: Array<PrintInput | null | undefined>): string {
|
|
38
|
-
const rendered: Array<string> = []
|
|
39
|
-
for (const part of parts) {
|
|
40
|
-
if (part === null || part === undefined || part === '') continue
|
|
41
|
-
const text = typeof part === 'string' ? part : printFrontmatter(part)
|
|
42
|
-
if (text) rendered.push(text.trimEnd())
|
|
43
|
-
}
|
|
44
|
-
return rendered.join('\n\n')
|
|
45
|
-
}
|
|
File without changes
|