@varavel/vdl-plugin-sdk 0.1.0 → 0.1.2
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/README.md +52 -4
- package/bin/vdl-plugin.js +31 -12
- package/dist/index.cjs +75 -0
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +36 -1
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.ts +36 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +72 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +1 -0
- package/src/utils/options.test.ts +88 -0
- package/src/utils/options.ts +115 -0
package/README.md
CHANGED
|
@@ -47,6 +47,7 @@ npm install @varavel/vdl-plugin-sdk
|
|
|
47
47
|
- Generated VDL IR types exported directly from the package.
|
|
48
48
|
- `getAnnotation` and `getAnnotationArgs` for reading annotations.
|
|
49
49
|
- `unwrapLiteral<T>()` for reading constants and annotation values.
|
|
50
|
+
- `getOptionString`, `getOptionBool`, `getOptionNumber`, and `getOptionArray` for reading plugin options.
|
|
50
51
|
- A `vdl-plugin` binary that supports `check` and `build`.
|
|
51
52
|
|
|
52
53
|
## Quick Start
|
|
@@ -58,8 +59,12 @@ Create `src/index.ts` in your plugin project:
|
|
|
58
59
|
```ts
|
|
59
60
|
import { definePlugin } from "@varavel/vdl-plugin-sdk";
|
|
60
61
|
|
|
61
|
-
export const generate = definePlugin((
|
|
62
|
-
// Your plugin logic goes here
|
|
62
|
+
export const generate = definePlugin((input) => {
|
|
63
|
+
// Your plugin logic goes here
|
|
64
|
+
// Feel free to explore the plugin input
|
|
65
|
+
console.log(input.version) // The VDL version without v prefix
|
|
66
|
+
console.log(input.options) // Any option that the user passed to the plugin via vdl.config.vdl
|
|
67
|
+
console.log(input.ir) // VDL intermediate representation from where your plugin generates code
|
|
63
68
|
|
|
64
69
|
return {
|
|
65
70
|
files: [
|
|
@@ -79,8 +84,51 @@ Every plugin follows the same release flow:
|
|
|
79
84
|
1. Create and export a `definePlugin(...)` handler in `./src/index.ts`.
|
|
80
85
|
2. Run `vdl-plugin build` to bundle the plugin into `./dist/index.js`.
|
|
81
86
|
3. Commit `./dist/index.js` to the repository.
|
|
82
|
-
4. Publish a new release on GitHub including all your files
|
|
83
|
-
5. When the plugin is used, VDL reads `./dist/index.js` directly from your GitHub
|
|
87
|
+
4. Publish a new release on GitHub including all your files, including `./dist/index.js`.
|
|
88
|
+
5. When the plugin is used, VDL reads `./dist/index.js` directly from your GitHub releases.
|
|
89
|
+
|
|
90
|
+
## API
|
|
91
|
+
|
|
92
|
+
Import every helper below from `@varavel/vdl-plugin-sdk`. The generated IR types are also exported from the same package.
|
|
93
|
+
|
|
94
|
+
### Plugin API
|
|
95
|
+
|
|
96
|
+
- `definePlugin(handler)` wraps and returns your plugin entrypoint.
|
|
97
|
+
- `VdlPluginHandler` is the function type for a plugin handler.
|
|
98
|
+
|
|
99
|
+
### Annotation API
|
|
100
|
+
|
|
101
|
+
- `getAnnotation(annotations, name)` returns the first matching annotation or `undefined`.
|
|
102
|
+
- `getAnnotationArgs(annotations, name)` returns the raw literal argument stored in the annotation.
|
|
103
|
+
|
|
104
|
+
### Literal API
|
|
105
|
+
|
|
106
|
+
- `unwrapLiteral<T>(value)` resolves a `LiteralValue` into a plain JavaScript value.
|
|
107
|
+
|
|
108
|
+
### Option API
|
|
109
|
+
|
|
110
|
+
Use these helpers to read `input.options` safely:
|
|
111
|
+
|
|
112
|
+
- `getOptionString(options, key, defaultValue)` reads string values.
|
|
113
|
+
- `getOptionBool(options, key, defaultValue)` reads booleans from truthy/falsy values.
|
|
114
|
+
- Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.
|
|
115
|
+
- Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.
|
|
116
|
+
- `getOptionNumber(options, key, defaultValue)` parses numbers and falls back safely for invalid input.
|
|
117
|
+
- `getOptionArray(options, key, defaultValue?, separator?)` splits a delimited string into a trimmed string array.
|
|
118
|
+
|
|
119
|
+
```ts
|
|
120
|
+
import {
|
|
121
|
+
getOptionArray,
|
|
122
|
+
getOptionBool,
|
|
123
|
+
getOptionNumber,
|
|
124
|
+
getOptionString,
|
|
125
|
+
} from "@varavel/vdl-plugin-sdk";
|
|
126
|
+
|
|
127
|
+
const prefix = getOptionString(input.options, "prefix", "Model");
|
|
128
|
+
const strict = getOptionBool(input.options, "strict", false);
|
|
129
|
+
const version = getOptionNumber(input.options, "version", 1);
|
|
130
|
+
const tags = getOptionArray(input.options, "tags", [], ",");
|
|
131
|
+
```
|
|
84
132
|
|
|
85
133
|
## CLI
|
|
86
134
|
|
package/bin/vdl-plugin.js
CHANGED
|
@@ -6,30 +6,49 @@ import { resolve } from "node:path";
|
|
|
6
6
|
import * as esbuild from "esbuild";
|
|
7
7
|
|
|
8
8
|
const require = createRequire(import.meta.url);
|
|
9
|
-
const
|
|
9
|
+
const args = process.argv.slice(2);
|
|
10
|
+
const command = args[0];
|
|
11
|
+
const flags = new Set(args.slice(1));
|
|
12
|
+
|
|
13
|
+
const GREEN = "\x1b[32m";
|
|
14
|
+
const RED = "\x1b[31m";
|
|
15
|
+
const CYAN = "\x1b[36m";
|
|
16
|
+
const RESET = "\x1b[0m";
|
|
17
|
+
|
|
18
|
+
const log = {
|
|
19
|
+
info: (msg) => console.log(`${CYAN}[i]${RESET} ${msg}`),
|
|
20
|
+
ok: (msg) => console.log(`${GREEN}[✓]${RESET} ${msg}`),
|
|
21
|
+
error: (msg) => console.error(`${RED}[✗]${RESET} ${msg}`),
|
|
22
|
+
};
|
|
10
23
|
|
|
11
24
|
function printHelp() {
|
|
12
|
-
console.log(`Usage: vdl-plugin <command>
|
|
25
|
+
console.log(`Usage: vdl-plugin <command> [options]
|
|
13
26
|
|
|
14
27
|
Commands:
|
|
15
|
-
check
|
|
16
|
-
build
|
|
28
|
+
check Run TypeScript type checks without emitting files
|
|
29
|
+
build Bundle the plugin from src/index.ts into dist/index.js
|
|
30
|
+
|
|
31
|
+
Build options:
|
|
32
|
+
--no-minify Disable minification (minification is enabled by default)`);
|
|
17
33
|
}
|
|
18
34
|
|
|
19
35
|
function runCheck() {
|
|
20
|
-
|
|
36
|
+
log.info("Running TypeScript type checks...");
|
|
21
37
|
|
|
22
38
|
try {
|
|
23
39
|
const tscPath = require.resolve("typescript/bin/tsc");
|
|
24
40
|
execFileSync(process.execPath, [tscPath, "--noEmit"], { stdio: "inherit" });
|
|
25
|
-
|
|
41
|
+
log.ok("Type checks completed successfully.");
|
|
26
42
|
} catch {
|
|
43
|
+
log.error("Type checks failed.");
|
|
27
44
|
process.exit(1);
|
|
28
45
|
}
|
|
29
46
|
}
|
|
30
47
|
|
|
31
48
|
function runBuild() {
|
|
32
|
-
|
|
49
|
+
const minify = !flags.has("--no-minify");
|
|
50
|
+
|
|
51
|
+
log.info(`Building VDL plugin${minify ? "" : " (minification disabled)"}...`);
|
|
33
52
|
|
|
34
53
|
try {
|
|
35
54
|
esbuild.buildSync({
|
|
@@ -39,15 +58,15 @@ function runBuild() {
|
|
|
39
58
|
platform: "neutral",
|
|
40
59
|
target: "es2015",
|
|
41
60
|
bundle: true,
|
|
42
|
-
minify
|
|
61
|
+
minify,
|
|
43
62
|
treeShaking: true,
|
|
44
63
|
});
|
|
45
64
|
|
|
46
|
-
|
|
65
|
+
log.ok("Plugin built successfully at dist/index.js.");
|
|
47
66
|
} catch (error) {
|
|
48
|
-
|
|
67
|
+
log.error("Failed to build the plugin.");
|
|
49
68
|
if (error instanceof Error && error.message) {
|
|
50
|
-
|
|
69
|
+
log.error(error.message);
|
|
51
70
|
}
|
|
52
71
|
process.exit(1);
|
|
53
72
|
}
|
|
@@ -59,7 +78,7 @@ if (command === "check") {
|
|
|
59
78
|
runBuild();
|
|
60
79
|
} else {
|
|
61
80
|
if (command) {
|
|
62
|
-
|
|
81
|
+
log.error(`Unknown command: ${command}`);
|
|
63
82
|
}
|
|
64
83
|
printHelp();
|
|
65
84
|
process.exit(1);
|
package/dist/index.cjs
CHANGED
|
@@ -529,6 +529,77 @@ function unwrapLiteralValue(value) {
|
|
|
529
529
|
}
|
|
530
530
|
}
|
|
531
531
|
//#endregion
|
|
532
|
+
//#region src/utils/options.ts
|
|
533
|
+
/**
|
|
534
|
+
* Returns a string option or the provided fallback when the key is missing.
|
|
535
|
+
*/
|
|
536
|
+
function getOptionString(options, key, defaultValue) {
|
|
537
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
538
|
+
return value === void 0 ? defaultValue : value;
|
|
539
|
+
}
|
|
540
|
+
/**
|
|
541
|
+
* Returns a boolean option using common truthy and falsy string values.
|
|
542
|
+
*
|
|
543
|
+
* Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.
|
|
544
|
+
*
|
|
545
|
+
* Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.
|
|
546
|
+
*
|
|
547
|
+
* Invalid values fall back to the provided default.
|
|
548
|
+
*/
|
|
549
|
+
function getOptionBool(options, key, defaultValue) {
|
|
550
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
551
|
+
if (value === void 0) return defaultValue;
|
|
552
|
+
switch (value.trim().toLowerCase()) {
|
|
553
|
+
case "true":
|
|
554
|
+
case "1":
|
|
555
|
+
case "yes":
|
|
556
|
+
case "on":
|
|
557
|
+
case "enable":
|
|
558
|
+
case "enabled":
|
|
559
|
+
case "y": return true;
|
|
560
|
+
case "false":
|
|
561
|
+
case "0":
|
|
562
|
+
case "no":
|
|
563
|
+
case "off":
|
|
564
|
+
case "disable":
|
|
565
|
+
case "disabled":
|
|
566
|
+
case "n": return false;
|
|
567
|
+
default: return defaultValue;
|
|
568
|
+
}
|
|
569
|
+
}
|
|
570
|
+
/**
|
|
571
|
+
* Returns a numeric option or the provided fallback when parsing fails.
|
|
572
|
+
*
|
|
573
|
+
* Empty, invalid, and non-finite values fall back to the default.
|
|
574
|
+
*/
|
|
575
|
+
function getOptionNumber(options, key, defaultValue) {
|
|
576
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
577
|
+
if (value === void 0) return defaultValue;
|
|
578
|
+
const trimmedValue = value.trim();
|
|
579
|
+
if (trimmedValue === "") return defaultValue;
|
|
580
|
+
const parsedValue = Number(trimmedValue);
|
|
581
|
+
return Number.isFinite(parsedValue) ? parsedValue : defaultValue;
|
|
582
|
+
}
|
|
583
|
+
/**
|
|
584
|
+
* Returns a string array option from a separator-delimited value.
|
|
585
|
+
*
|
|
586
|
+
* Empty items are removed and each entry is trimmed.
|
|
587
|
+
*
|
|
588
|
+
* Missing values return the provided default.
|
|
589
|
+
*
|
|
590
|
+
* @example
|
|
591
|
+
* // For options: { "features": "feature1, feature2, feature3" }
|
|
592
|
+
* getOptionArray(options, "features", [], ",")
|
|
593
|
+
* // returns ["feature1", "feature2", "feature3"]
|
|
594
|
+
*/
|
|
595
|
+
function getOptionArray(options, key, defaultValue = [], separator = ",") {
|
|
596
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
597
|
+
if (value === void 0) return defaultValue;
|
|
598
|
+
const trimmedValue = value.trim();
|
|
599
|
+
if (trimmedValue === "") return [];
|
|
600
|
+
return trimmedValue.split(separator).map((item) => item.trim()).filter((item) => item.length > 0);
|
|
601
|
+
}
|
|
602
|
+
//#endregion
|
|
532
603
|
exports.EnumValueTypeList = EnumValueTypeList;
|
|
533
604
|
exports.LiteralKindList = LiteralKindList;
|
|
534
605
|
exports.PrimitiveTypeList = PrimitiveTypeList;
|
|
@@ -536,6 +607,10 @@ exports.TypeKindList = TypeKindList;
|
|
|
536
607
|
exports.definePlugin = definePlugin;
|
|
537
608
|
exports.getAnnotation = getAnnotation;
|
|
538
609
|
exports.getAnnotationArgs = getAnnotationArgs;
|
|
610
|
+
exports.getOptionArray = getOptionArray;
|
|
611
|
+
exports.getOptionBool = getOptionBool;
|
|
612
|
+
exports.getOptionNumber = getOptionNumber;
|
|
613
|
+
exports.getOptionString = getOptionString;
|
|
539
614
|
exports.hydrateAnnotation = hydrateAnnotation;
|
|
540
615
|
exports.hydrateConstantDef = hydrateConstantDef;
|
|
541
616
|
exports.hydrateEnumDef = hydrateEnumDef;
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","names":[],"sources":["../src/define-plugin.ts","../src/types/types.ts","../src/utils/annotations.ts","../src/utils/literals.ts"],"sourcesContent":["import type { PluginInput, PluginOutput } from \"./types\";\n\n/**\n * Defines a VDL plugin handler function.\n *\n * @param input - The input data for the plugin containing the IR and other relevant information.\n * @returns The output data from the plugin containing the generated files and any errors.\n */\nexport type VdlPluginHandler = (input: PluginInput) => PluginOutput;\n\n/**\n * Defines a VDL plugin by wrapping the provided handler function. This is a helper function\n * that can be used to create plugins in a more concise way.\n *\n * Example usage:\n * ```typescript\n * import { definePlugin } from \"@varavel/vdl-plugin-sdk\";\n *\n * export const generate = definePlugin((input) => {\n * // Plugin logic goes here\n * return {\n * files: [],\n * errors: []\n * };\n * });\n * ```\n *\n * @param handler - The plugin handler function that contains the logic for processing the input and generating the output.\n * @returns The same handler function, which can be exported as the plugin's main entry point.\n */\nexport function definePlugin(handler: VdlPluginHandler): VdlPluginHandler {\n return handler;\n}\n","// Code generated by VDL v0.4.0-alpha.5. DO NOT EDIT.\n// If you edit this file, it will be overwritten the next time it is generated.\n//\n// For more information about VDL, visit https://vdl.varavel.com\n\n/* eslint-disable */\n/* tslint:disable */\n// biome-ignore-all lint: Generated by VDL\n\n// -----------------------------------------------------------------------------\n// Enumerations\n// -----------------------------------------------------------------------------\n\n/**\n * Underlying storage kind used by an enum\n */\nexport type EnumValueType = \"string\" | \"int\";\n\nexport const EnumValueTypeList: EnumValueType[] = [\n \"string\",\n \"int\",\n];\n\nexport function isEnumValueType(value: unknown): value is EnumValueType {\n return EnumValueTypeList.includes(value as EnumValueType);\n}\n\n/**\n * Kind discriminator for LiteralValue.\n * \n * LiteralValue is used for fully resolved literal data in:\n * \n * - constant values\n * - annotation arguments\n */\nexport type LiteralKind = \"string\" | \"int\" | \"float\" | \"bool\" | \"object\" | \"array\";\n\nexport const LiteralKindList: LiteralKind[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"object\",\n \"array\",\n];\n\nexport function isLiteralKind(value: unknown): value is LiteralKind {\n return LiteralKindList.includes(value as LiteralKind);\n}\n\n/**\n * Primitive scalar type names\n */\nexport type PrimitiveType = \"string\" | \"int\" | \"float\" | \"bool\" | \"datetime\";\n\nexport const PrimitiveTypeList: PrimitiveType[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"datetime\",\n];\n\nexport function isPrimitiveType(value: unknown): value is PrimitiveType {\n return PrimitiveTypeList.includes(value as PrimitiveType);\n}\n\n/**\n * Kind discriminator for TypeRef\n */\nexport type TypeKind = \"primitive\" | \"type\" | \"enum\" | \"array\" | \"map\" | \"object\";\n\nexport const TypeKindList: TypeKind[] = [\n \"primitive\",\n \"type\",\n \"enum\",\n \"array\",\n \"map\",\n \"object\",\n];\n\nexport function isTypeKind(value: unknown): value is TypeKind {\n return TypeKindList.includes(value as TypeKind);\n}\n\n// -----------------------------------------------------------------------------\n// Domain Types\n// -----------------------------------------------------------------------------\n\n/**\n * Annotation Annotation metadata preserved in IR.\n * \n * `name` is the annotation identifier without the `@` prefix.\n * `argument`, when present, is fully resolved as a LiteralValue.\n */\nexport type Annotation = {\n position: Position\n name: string\n argument?: LiteralValue\n}\n\nexport function hydrateAnnotation(input: Annotation): Annotation {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedArgument = input.argument ? hydrateLiteralValue(input.argument) : input.argument\n return {\n position: hydratedPosition,\n name: hydratedName,\n argument: hydratedArgument,\n }\n}\n\nexport function validateAnnotation(input: unknown, path = \"Annotation\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.argument !== undefined && obj.argument !== null) {\n {\n const err = validateLiteralValue(obj.argument, `${path}.argument`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * ConstantDef Fully resolved constant definition.\n * \n * `typeRef` is explicit or inferred by analysis.\n * `value` contains the fully resolved literal payload.\n */\nexport type ConstantDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n value: LiteralValue\n}\n\nexport function hydrateConstantDef(input: ConstantDef): ConstantDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n value: hydratedValue,\n }\n}\n\nexport function validateConstantDef(input: unknown, path = \"ConstantDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * EnumDef Flattened enum definition.\n * \n * All enum spreads are already expanded into `members`.\n */\nexport type EnumDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n enumType: EnumValueType\n members: EnumMember[]\n}\n\nexport function hydrateEnumDef(input: EnumDef): EnumDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedEnumType = input.enumType\n const hydratedMembers = input.members.map(el => hydrateEnumMember(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n enumType: hydratedEnumType,\n members: hydratedMembers,\n }\n}\n\nexport function validateEnumDef(input: unknown, path = \"EnumDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enumType === undefined || obj.enumType === null) {\n return `${path}.enumType: required field is missing`;\n }\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n if (obj.members === undefined || obj.members === null) {\n return `${path}.members: required field is missing`;\n }\n {\n if (!Array.isArray(obj.members)) {\n return `${path}.members: expected array, got ${typeof obj.members}`;\n }\n for (let i = 0; i < obj.members.length; i++) {\n {\n const err = validateEnumMember(obj.members[i], `${path}.members[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * EnumMember Enum member definition\n */\nexport type EnumMember = {\n position: Position\n name: string\n value: LiteralValue\n doc?: string\n annotations: Annotation[]\n}\n\nexport function hydrateEnumMember(input: EnumMember): EnumMember {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedValue = hydrateLiteralValue(input.value)\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n value: hydratedValue,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n }\n}\n\nexport function validateEnumMember(input: unknown, path = \"EnumMember\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * Field Flattened object/type field definition\n */\nexport type Field = {\n position: Position\n name: string\n doc?: string\n optional: boolean\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateField(input: Field): Field {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedOptional = input.optional\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n optional: hydratedOptional,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateField(input: unknown, path = \"Field\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * IrSchema IrSchema is the generator-facing representation of a VDL program.\n * \n * This model is intentionally \"flat\" and \"resolved\":\n * \n * - spreads are already expanded\n * - references are already resolved\n * - collections are in deterministic order\n * \n * A code generator should be able to consume IrSchema directly, without needing\n * to re-run parser or semantic-analysis logic.\n */\nexport type IrSchema = {\n entryPoint: string\n constants: ConstantDef[]\n enums: EnumDef[]\n types: TypeDef[]\n docs: TopLevelDoc[]\n}\n\nexport function hydrateIrSchema(input: IrSchema): IrSchema {\n const hydratedEntryPoint = input.entryPoint\n const hydratedConstants = input.constants.map(el => hydrateConstantDef(el))\n const hydratedEnums = input.enums.map(el => hydrateEnumDef(el))\n const hydratedTypes = input.types.map(el => hydrateTypeDef(el))\n const hydratedDocs = input.docs.map(el => hydrateTopLevelDoc(el))\n return {\n entryPoint: hydratedEntryPoint,\n constants: hydratedConstants,\n enums: hydratedEnums,\n types: hydratedTypes,\n docs: hydratedDocs,\n }\n}\n\nexport function validateIrSchema(input: unknown, path = \"IrSchema\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.constants === undefined || obj.constants === null) {\n return `${path}.constants: required field is missing`;\n }\n {\n if (!Array.isArray(obj.constants)) {\n return `${path}.constants: expected array, got ${typeof obj.constants}`;\n }\n for (let i = 0; i < obj.constants.length; i++) {\n {\n const err = validateConstantDef(obj.constants[i], `${path}.constants[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enums === undefined || obj.enums === null) {\n return `${path}.enums: required field is missing`;\n }\n {\n if (!Array.isArray(obj.enums)) {\n return `${path}.enums: expected array, got ${typeof obj.enums}`;\n }\n for (let i = 0; i < obj.enums.length; i++) {\n {\n const err = validateEnumDef(obj.enums[i], `${path}.enums[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.types === undefined || obj.types === null) {\n return `${path}.types: required field is missing`;\n }\n {\n if (!Array.isArray(obj.types)) {\n return `${path}.types: expected array, got ${typeof obj.types}`;\n }\n for (let i = 0; i < obj.types.length; i++) {\n {\n const err = validateTypeDef(obj.types[i], `${path}.types[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.docs === undefined || obj.docs === null) {\n return `${path}.docs: required field is missing`;\n }\n {\n if (!Array.isArray(obj.docs)) {\n return `${path}.docs: expected array, got ${typeof obj.docs}`;\n }\n for (let i = 0; i < obj.docs.length; i++) {\n {\n const err = validateTopLevelDoc(obj.docs[i], `${path}.docs[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * LiteralValue Fully resolved literal value.\n * \n * The selected payload is determined by `kind`:\n * \n * - `string` -> `stringValue`\n * - `int` -> `intValue`\n * - `float` -> `floatValue`\n * - `bool` -> `boolValue`\n * - `object` -> `objectEntries`\n * - `array` -> `arrayItems`\n */\nexport type LiteralValue = {\n position: Position\n kind: LiteralKind\n stringValue?: string\n intValue?: number\n floatValue?: number\n boolValue?: boolean\n objectEntries?: ObjectEntry[]\n arrayItems?: LiteralValue[]\n}\n\nexport function hydrateLiteralValue(input: LiteralValue): LiteralValue {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKind = input.kind\n const hydratedStringValue = input.stringValue ? input.stringValue : input.stringValue\n const hydratedIntValue = input.intValue ? input.intValue : input.intValue\n const hydratedFloatValue = input.floatValue ? input.floatValue : input.floatValue\n const hydratedBoolValue = input.boolValue ? input.boolValue : input.boolValue\n const hydratedObjectEntries = input.objectEntries ? input.objectEntries.map(el => hydrateObjectEntry(el)) : input.objectEntries\n const hydratedArrayItems = input.arrayItems ? input.arrayItems.map(el => hydrateLiteralValue(el)) : input.arrayItems\n return {\n position: hydratedPosition,\n kind: hydratedKind,\n stringValue: hydratedStringValue,\n intValue: hydratedIntValue,\n floatValue: hydratedFloatValue,\n boolValue: hydratedBoolValue,\n objectEntries: hydratedObjectEntries,\n arrayItems: hydratedArrayItems,\n }\n}\n\nexport function validateLiteralValue(input: unknown, path = \"LiteralValue\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isLiteralKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for LiteralKind`;\n }\n }\n if (obj.objectEntries !== undefined && obj.objectEntries !== null) {\n {\n if (!Array.isArray(obj.objectEntries)) {\n return `${path}.objectEntries: expected array, got ${typeof obj.objectEntries}`;\n }\n for (let i = 0; i < obj.objectEntries.length; i++) {\n {\n const err = validateObjectEntry(obj.objectEntries[i], `${path}.objectEntries[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.arrayItems !== undefined && obj.arrayItems !== null) {\n {\n if (!Array.isArray(obj.arrayItems)) {\n return `${path}.arrayItems: expected array, got ${typeof obj.arrayItems}`;\n }\n for (let i = 0; i < obj.arrayItems.length; i++) {\n {\n const err = validateLiteralValue(obj.arrayItems[i], `${path}.arrayItems[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * ObjectEntry Key/value pair inside an object LiteralValue payload\n */\nexport type ObjectEntry = {\n position: Position\n key: string\n value: LiteralValue\n}\n\nexport function hydrateObjectEntry(input: ObjectEntry): ObjectEntry {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKey = input.key\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n key: hydratedKey,\n value: hydratedValue,\n }\n}\n\nexport function validateObjectEntry(input: unknown, path = \"ObjectEntry\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginInput PluginInput represents the data payload sent to a plugin.\n * \n * The plugin receives this as a single argument containing the complete\n * Intermediate Representation of the VDL schema along with any user-defined\n * configuration options from `vdl.config.vdl`.\n */\nexport type PluginInput = {\n version: string\n ir: IrSchema\n options: Record<string, string>\n}\n\nexport function hydratePluginInput(input: PluginInput): PluginInput {\n const hydratedVersion = input.version\n const hydratedIr = hydrateIrSchema(input.ir)\n const hydratedOptions = input.options\n return {\n version: hydratedVersion,\n ir: hydratedIr,\n options: hydratedOptions,\n }\n}\n\nexport function validatePluginInput(input: unknown, path = \"PluginInput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.ir === undefined || obj.ir === null) {\n return `${path}.ir: required field is missing`;\n }\n {\n const err = validateIrSchema(obj.ir, `${path}.ir`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginOutput PluginOutput represents the response payload returned by the `plugin` function.\n * \n * After processing the input schema, the plugin outputs this object containing\n * all files to be generated or errors to be displayed to the user.\n * \n * If there are no errors and at least one file is returned, VDL will write each\n * file to the specified path within the output directory. If there are errors,\n * VDL will display them to the user and not write any files.\n */\nexport type PluginOutput = {\n files?: PluginOutputFile[]\n errors?: PluginOutputError[]\n}\n\nexport function hydratePluginOutput(input: PluginOutput): PluginOutput {\n const hydratedFiles = input.files ? input.files.map(el => hydratePluginOutputFile(el)) : input.files\n const hydratedErrors = input.errors ? input.errors.map(el => hydratePluginOutputError(el)) : input.errors\n return {\n files: hydratedFiles,\n errors: hydratedErrors,\n }\n}\n\nexport function validatePluginOutput(input: unknown, path = \"PluginOutput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.files !== undefined && obj.files !== null) {\n {\n if (!Array.isArray(obj.files)) {\n return `${path}.files: expected array, got ${typeof obj.files}`;\n }\n for (let i = 0; i < obj.files.length; i++) {\n {\n const err = validatePluginOutputFile(obj.files[i], `${path}.files[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.errors !== undefined && obj.errors !== null) {\n {\n if (!Array.isArray(obj.errors)) {\n return `${path}.errors: expected array, got ${typeof obj.errors}`;\n }\n for (let i = 0; i < obj.errors.length; i++) {\n {\n const err = validatePluginOutputError(obj.errors[i], `${path}.errors[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * PluginOutputError A structured error reported by the plugin.\n */\nexport type PluginOutputError = {\n message: string\n position?: Position\n}\n\nexport function hydratePluginOutputError(input: PluginOutputError): PluginOutputError {\n const hydratedMessage = input.message\n const hydratedPosition = input.position ? hydratePosition(input.position) : input.position\n return {\n message: hydratedMessage,\n position: hydratedPosition,\n }\n}\n\nexport function validatePluginOutputError(input: unknown, path = \"PluginOutputError\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position !== undefined && obj.position !== null) {\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * PluginOutputFile PluginOutputFile represents a single generated file produced by the plugin.\n * \n * This abstraction allows plugins to generate multiple files from a single\n * invocation, enabling patterns like one-file-per-type or splitting large\n * outputs across multiple modules.\n */\nexport type PluginOutputFile = {\n path: string\n content: string\n}\n\nexport function hydratePluginOutputFile(input: PluginOutputFile): PluginOutputFile {\n const hydratedPath = input.path\n const hydratedContent = input.content\n return {\n path: hydratedPath,\n content: hydratedContent,\n }\n}\n\nexport function validatePluginOutputFile(_input: unknown, _path = \"PluginOutputFile\"): string | null {\n return null;\n}\n\n/**\n * Position It represents a position within a file and is used for error\n * reporting, diagnostics, plugins, and tooling support.\n */\nexport type Position = {\n file: string\n line: number\n column: number\n}\n\nexport function hydratePosition(input: Position): Position {\n const hydratedFile = input.file\n const hydratedLine = input.line\n const hydratedColumn = input.column\n return {\n file: hydratedFile,\n line: hydratedLine,\n column: hydratedColumn,\n }\n}\n\nexport function validatePosition(_input: unknown, _path = \"Position\"): string | null {\n return null;\n}\n\n/**\n * TopLevelDoc Standalone documentation block.\n * \n * Used for top-level docstrings that are not attached to a type/enum/constant.\n */\nexport type TopLevelDoc = {\n position: Position\n content: string\n}\n\nexport function hydrateTopLevelDoc(input: TopLevelDoc): TopLevelDoc {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedContent = input.content\n return {\n position: hydratedPosition,\n content: hydratedContent,\n }\n}\n\nexport function validateTopLevelDoc(input: unknown, path = \"TopLevelDoc\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeDef Flattened type definition.\n * \n * All spreads are already expanded. The unified `typeRef` describes what this\n * type IS, a primitive, custom reference, map, array, or object with fields.\n */\nexport type TypeDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateTypeDef(input: TypeDef): TypeDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateTypeDef(input: unknown, path = \"TypeDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeRef Normalized type reference used by fields and constants.\n * \n * `kind` selects which payload fields are meaningful. Generators should inspect\n * `kind` first, then read the related payload fields.\n */\nexport type TypeRef = {\n kind: TypeKind\n primitiveName?: PrimitiveType\n typeName?: string\n enumName?: string\n enumType?: EnumValueType\n arrayType?: TypeRef\n arrayDims?: number\n mapType?: TypeRef\n objectFields?: Field[]\n}\n\nexport function hydrateTypeRef(input: TypeRef): TypeRef {\n const hydratedKind = input.kind\n const hydratedPrimitiveName = input.primitiveName ? input.primitiveName : input.primitiveName\n const hydratedTypeName = input.typeName ? input.typeName : input.typeName\n const hydratedEnumName = input.enumName ? input.enumName : input.enumName\n const hydratedEnumType = input.enumType ? input.enumType : input.enumType\n const hydratedArrayType = input.arrayType ? hydrateTypeRef(input.arrayType) : input.arrayType\n const hydratedArrayDims = input.arrayDims ? input.arrayDims : input.arrayDims\n const hydratedMapType = input.mapType ? hydrateTypeRef(input.mapType) : input.mapType\n const hydratedObjectFields = input.objectFields ? input.objectFields.map(el => hydrateField(el)) : input.objectFields\n return {\n kind: hydratedKind,\n primitiveName: hydratedPrimitiveName,\n typeName: hydratedTypeName,\n enumName: hydratedEnumName,\n enumType: hydratedEnumType,\n arrayType: hydratedArrayType,\n arrayDims: hydratedArrayDims,\n mapType: hydratedMapType,\n objectFields: hydratedObjectFields,\n }\n}\n\nexport function validateTypeRef(input: unknown, path = \"TypeRef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isTypeKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for TypeKind`;\n }\n }\n if (obj.primitiveName !== undefined && obj.primitiveName !== null) {\n {\n if (!isPrimitiveType(obj.primitiveName)) {\n return `${path}.primitiveName: invalid enum value '${obj.primitiveName}' for PrimitiveType`;\n }\n }\n }\n if (obj.enumType !== undefined && obj.enumType !== null) {\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n }\n if (obj.arrayType !== undefined && obj.arrayType !== null) {\n {\n const err = validateTypeRef(obj.arrayType, `${path}.arrayType`);\n if (err !== null) return err;\n }\n }\n if (obj.mapType !== undefined && obj.mapType !== null) {\n {\n const err = validateTypeRef(obj.mapType, `${path}.mapType`);\n if (err !== null) return err;\n }\n }\n if (obj.objectFields !== undefined && obj.objectFields !== null) {\n {\n if (!Array.isArray(obj.objectFields)) {\n return `${path}.objectFields: expected array, got ${typeof obj.objectFields}`;\n }\n for (let i = 0; i < obj.objectFields.length; i++) {\n {\n const err = validateField(obj.objectFields[i], `${path}.objectFields[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n","import type { Annotation, LiteralValue } from \"../types\";\n\n/**\n * Returns the first annotation that matches the provided name.\n */\nexport function getAnnotation(\n annotations: Annotation[] | undefined,\n name: string,\n): Annotation | undefined {\n if (!annotations) return undefined;\n return annotations.find((anno) => anno.name === name);\n}\n\n/**\n * Returns the raw literal argument stored in an annotation.\n *\n * VDL annotations currently expose a single literal argument.\n * Pair this helper with `unwrapLiteral` when you need a plain JavaScript value.\n */\nexport function getAnnotationArgs(\n annotations: Annotation[] | undefined,\n name: string,\n): LiteralValue | undefined {\n const anno = getAnnotation(annotations, name);\n return anno?.argument;\n}\n","import type { LiteralValue } from \"../types\";\n\n/**\n * Native JavaScript value produced by `unwrapLiteral`.\n *\n * `undefined` is preserved when a literal is missing its kind-specific payload.\n * `null` is returned for unknown literal kinds to keep the resolver non-throwing.\n */\nexport type UnwrappedLiteral =\n | string\n | number\n | boolean\n | null\n | undefined\n | UnwrappedLiteral[]\n | { [key: string]: UnwrappedLiteral };\n\n/**\n * Resolves a `LiteralValue` into its native JavaScript representation.\n *\n * Pass a generic when you already know the expected shape.\n * Omit it to get `unknown` and narrow the result yourself.\n *\n * The generic only affects TypeScript types. It does not validate the runtime value.\n */\nexport function unwrapLiteral<T = unknown>(value: LiteralValue): T {\n return unwrapLiteralValue(value) as T;\n}\n\n/**\n * Performs the recursive literal resolution used by `unwrapLiteral`.\n */\nfunction unwrapLiteralValue(value: LiteralValue): UnwrappedLiteral {\n switch (value.kind) {\n case \"string\":\n return value.stringValue;\n case \"int\":\n return value.intValue;\n case \"float\":\n return value.floatValue;\n case \"bool\":\n return value.boolValue;\n case \"object\": {\n const resolvedObject: { [key: string]: UnwrappedLiteral } = {};\n const entries = value.objectEntries ?? [];\n\n for (const entry of entries) {\n resolvedObject[entry.key] = unwrapLiteralValue(entry.value);\n }\n\n return resolvedObject;\n }\n case \"array\": {\n const items = value.arrayItems ?? [];\n return items.map((item) => unwrapLiteralValue(item));\n }\n default:\n return null;\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.cjs","names":[],"sources":["../src/define-plugin.ts","../src/types/types.ts","../src/utils/annotations.ts","../src/utils/literals.ts","../src/utils/options.ts"],"sourcesContent":["import type { PluginInput, PluginOutput } from \"./types\";\n\n/**\n * Defines a VDL plugin handler function.\n *\n * @param input - The input data for the plugin containing the IR and other relevant information.\n * @returns The output data from the plugin containing the generated files and any errors.\n */\nexport type VdlPluginHandler = (input: PluginInput) => PluginOutput;\n\n/**\n * Defines a VDL plugin by wrapping the provided handler function. This is a helper function\n * that can be used to create plugins in a more concise way.\n *\n * Example usage:\n * ```typescript\n * import { definePlugin } from \"@varavel/vdl-plugin-sdk\";\n *\n * export const generate = definePlugin((input) => {\n * // Plugin logic goes here\n * return {\n * files: [],\n * errors: []\n * };\n * });\n * ```\n *\n * @param handler - The plugin handler function that contains the logic for processing the input and generating the output.\n * @returns The same handler function, which can be exported as the plugin's main entry point.\n */\nexport function definePlugin(handler: VdlPluginHandler): VdlPluginHandler {\n return handler;\n}\n","// Code generated by VDL v0.4.0-alpha.5. DO NOT EDIT.\n// If you edit this file, it will be overwritten the next time it is generated.\n//\n// For more information about VDL, visit https://vdl.varavel.com\n\n/* eslint-disable */\n/* tslint:disable */\n// biome-ignore-all lint: Generated by VDL\n\n// -----------------------------------------------------------------------------\n// Enumerations\n// -----------------------------------------------------------------------------\n\n/**\n * Underlying storage kind used by an enum\n */\nexport type EnumValueType = \"string\" | \"int\";\n\nexport const EnumValueTypeList: EnumValueType[] = [\n \"string\",\n \"int\",\n];\n\nexport function isEnumValueType(value: unknown): value is EnumValueType {\n return EnumValueTypeList.includes(value as EnumValueType);\n}\n\n/**\n * Kind discriminator for LiteralValue.\n * \n * LiteralValue is used for fully resolved literal data in:\n * \n * - constant values\n * - annotation arguments\n */\nexport type LiteralKind = \"string\" | \"int\" | \"float\" | \"bool\" | \"object\" | \"array\";\n\nexport const LiteralKindList: LiteralKind[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"object\",\n \"array\",\n];\n\nexport function isLiteralKind(value: unknown): value is LiteralKind {\n return LiteralKindList.includes(value as LiteralKind);\n}\n\n/**\n * Primitive scalar type names\n */\nexport type PrimitiveType = \"string\" | \"int\" | \"float\" | \"bool\" | \"datetime\";\n\nexport const PrimitiveTypeList: PrimitiveType[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"datetime\",\n];\n\nexport function isPrimitiveType(value: unknown): value is PrimitiveType {\n return PrimitiveTypeList.includes(value as PrimitiveType);\n}\n\n/**\n * Kind discriminator for TypeRef\n */\nexport type TypeKind = \"primitive\" | \"type\" | \"enum\" | \"array\" | \"map\" | \"object\";\n\nexport const TypeKindList: TypeKind[] = [\n \"primitive\",\n \"type\",\n \"enum\",\n \"array\",\n \"map\",\n \"object\",\n];\n\nexport function isTypeKind(value: unknown): value is TypeKind {\n return TypeKindList.includes(value as TypeKind);\n}\n\n// -----------------------------------------------------------------------------\n// Domain Types\n// -----------------------------------------------------------------------------\n\n/**\n * Annotation Annotation metadata preserved in IR.\n * \n * `name` is the annotation identifier without the `@` prefix.\n * `argument`, when present, is fully resolved as a LiteralValue.\n */\nexport type Annotation = {\n position: Position\n name: string\n argument?: LiteralValue\n}\n\nexport function hydrateAnnotation(input: Annotation): Annotation {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedArgument = input.argument ? hydrateLiteralValue(input.argument) : input.argument\n return {\n position: hydratedPosition,\n name: hydratedName,\n argument: hydratedArgument,\n }\n}\n\nexport function validateAnnotation(input: unknown, path = \"Annotation\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.argument !== undefined && obj.argument !== null) {\n {\n const err = validateLiteralValue(obj.argument, `${path}.argument`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * ConstantDef Fully resolved constant definition.\n * \n * `typeRef` is explicit or inferred by analysis.\n * `value` contains the fully resolved literal payload.\n */\nexport type ConstantDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n value: LiteralValue\n}\n\nexport function hydrateConstantDef(input: ConstantDef): ConstantDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n value: hydratedValue,\n }\n}\n\nexport function validateConstantDef(input: unknown, path = \"ConstantDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * EnumDef Flattened enum definition.\n * \n * All enum spreads are already expanded into `members`.\n */\nexport type EnumDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n enumType: EnumValueType\n members: EnumMember[]\n}\n\nexport function hydrateEnumDef(input: EnumDef): EnumDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedEnumType = input.enumType\n const hydratedMembers = input.members.map(el => hydrateEnumMember(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n enumType: hydratedEnumType,\n members: hydratedMembers,\n }\n}\n\nexport function validateEnumDef(input: unknown, path = \"EnumDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enumType === undefined || obj.enumType === null) {\n return `${path}.enumType: required field is missing`;\n }\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n if (obj.members === undefined || obj.members === null) {\n return `${path}.members: required field is missing`;\n }\n {\n if (!Array.isArray(obj.members)) {\n return `${path}.members: expected array, got ${typeof obj.members}`;\n }\n for (let i = 0; i < obj.members.length; i++) {\n {\n const err = validateEnumMember(obj.members[i], `${path}.members[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * EnumMember Enum member definition\n */\nexport type EnumMember = {\n position: Position\n name: string\n value: LiteralValue\n doc?: string\n annotations: Annotation[]\n}\n\nexport function hydrateEnumMember(input: EnumMember): EnumMember {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedValue = hydrateLiteralValue(input.value)\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n value: hydratedValue,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n }\n}\n\nexport function validateEnumMember(input: unknown, path = \"EnumMember\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * Field Flattened object/type field definition\n */\nexport type Field = {\n position: Position\n name: string\n doc?: string\n optional: boolean\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateField(input: Field): Field {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedOptional = input.optional\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n optional: hydratedOptional,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateField(input: unknown, path = \"Field\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * IrSchema IrSchema is the generator-facing representation of a VDL program.\n * \n * This model is intentionally \"flat\" and \"resolved\":\n * \n * - spreads are already expanded\n * - references are already resolved\n * - collections are in deterministic order\n * \n * A code generator should be able to consume IrSchema directly, without needing\n * to re-run parser or semantic-analysis logic.\n */\nexport type IrSchema = {\n entryPoint: string\n constants: ConstantDef[]\n enums: EnumDef[]\n types: TypeDef[]\n docs: TopLevelDoc[]\n}\n\nexport function hydrateIrSchema(input: IrSchema): IrSchema {\n const hydratedEntryPoint = input.entryPoint\n const hydratedConstants = input.constants.map(el => hydrateConstantDef(el))\n const hydratedEnums = input.enums.map(el => hydrateEnumDef(el))\n const hydratedTypes = input.types.map(el => hydrateTypeDef(el))\n const hydratedDocs = input.docs.map(el => hydrateTopLevelDoc(el))\n return {\n entryPoint: hydratedEntryPoint,\n constants: hydratedConstants,\n enums: hydratedEnums,\n types: hydratedTypes,\n docs: hydratedDocs,\n }\n}\n\nexport function validateIrSchema(input: unknown, path = \"IrSchema\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.constants === undefined || obj.constants === null) {\n return `${path}.constants: required field is missing`;\n }\n {\n if (!Array.isArray(obj.constants)) {\n return `${path}.constants: expected array, got ${typeof obj.constants}`;\n }\n for (let i = 0; i < obj.constants.length; i++) {\n {\n const err = validateConstantDef(obj.constants[i], `${path}.constants[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enums === undefined || obj.enums === null) {\n return `${path}.enums: required field is missing`;\n }\n {\n if (!Array.isArray(obj.enums)) {\n return `${path}.enums: expected array, got ${typeof obj.enums}`;\n }\n for (let i = 0; i < obj.enums.length; i++) {\n {\n const err = validateEnumDef(obj.enums[i], `${path}.enums[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.types === undefined || obj.types === null) {\n return `${path}.types: required field is missing`;\n }\n {\n if (!Array.isArray(obj.types)) {\n return `${path}.types: expected array, got ${typeof obj.types}`;\n }\n for (let i = 0; i < obj.types.length; i++) {\n {\n const err = validateTypeDef(obj.types[i], `${path}.types[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.docs === undefined || obj.docs === null) {\n return `${path}.docs: required field is missing`;\n }\n {\n if (!Array.isArray(obj.docs)) {\n return `${path}.docs: expected array, got ${typeof obj.docs}`;\n }\n for (let i = 0; i < obj.docs.length; i++) {\n {\n const err = validateTopLevelDoc(obj.docs[i], `${path}.docs[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * LiteralValue Fully resolved literal value.\n * \n * The selected payload is determined by `kind`:\n * \n * - `string` -> `stringValue`\n * - `int` -> `intValue`\n * - `float` -> `floatValue`\n * - `bool` -> `boolValue`\n * - `object` -> `objectEntries`\n * - `array` -> `arrayItems`\n */\nexport type LiteralValue = {\n position: Position\n kind: LiteralKind\n stringValue?: string\n intValue?: number\n floatValue?: number\n boolValue?: boolean\n objectEntries?: ObjectEntry[]\n arrayItems?: LiteralValue[]\n}\n\nexport function hydrateLiteralValue(input: LiteralValue): LiteralValue {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKind = input.kind\n const hydratedStringValue = input.stringValue ? input.stringValue : input.stringValue\n const hydratedIntValue = input.intValue ? input.intValue : input.intValue\n const hydratedFloatValue = input.floatValue ? input.floatValue : input.floatValue\n const hydratedBoolValue = input.boolValue ? input.boolValue : input.boolValue\n const hydratedObjectEntries = input.objectEntries ? input.objectEntries.map(el => hydrateObjectEntry(el)) : input.objectEntries\n const hydratedArrayItems = input.arrayItems ? input.arrayItems.map(el => hydrateLiteralValue(el)) : input.arrayItems\n return {\n position: hydratedPosition,\n kind: hydratedKind,\n stringValue: hydratedStringValue,\n intValue: hydratedIntValue,\n floatValue: hydratedFloatValue,\n boolValue: hydratedBoolValue,\n objectEntries: hydratedObjectEntries,\n arrayItems: hydratedArrayItems,\n }\n}\n\nexport function validateLiteralValue(input: unknown, path = \"LiteralValue\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isLiteralKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for LiteralKind`;\n }\n }\n if (obj.objectEntries !== undefined && obj.objectEntries !== null) {\n {\n if (!Array.isArray(obj.objectEntries)) {\n return `${path}.objectEntries: expected array, got ${typeof obj.objectEntries}`;\n }\n for (let i = 0; i < obj.objectEntries.length; i++) {\n {\n const err = validateObjectEntry(obj.objectEntries[i], `${path}.objectEntries[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.arrayItems !== undefined && obj.arrayItems !== null) {\n {\n if (!Array.isArray(obj.arrayItems)) {\n return `${path}.arrayItems: expected array, got ${typeof obj.arrayItems}`;\n }\n for (let i = 0; i < obj.arrayItems.length; i++) {\n {\n const err = validateLiteralValue(obj.arrayItems[i], `${path}.arrayItems[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * ObjectEntry Key/value pair inside an object LiteralValue payload\n */\nexport type ObjectEntry = {\n position: Position\n key: string\n value: LiteralValue\n}\n\nexport function hydrateObjectEntry(input: ObjectEntry): ObjectEntry {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKey = input.key\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n key: hydratedKey,\n value: hydratedValue,\n }\n}\n\nexport function validateObjectEntry(input: unknown, path = \"ObjectEntry\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginInput PluginInput represents the data payload sent to a plugin.\n * \n * The plugin receives this as a single argument containing the complete\n * Intermediate Representation of the VDL schema along with any user-defined\n * configuration options from `vdl.config.vdl`.\n */\nexport type PluginInput = {\n version: string\n ir: IrSchema\n options: Record<string, string>\n}\n\nexport function hydratePluginInput(input: PluginInput): PluginInput {\n const hydratedVersion = input.version\n const hydratedIr = hydrateIrSchema(input.ir)\n const hydratedOptions = input.options\n return {\n version: hydratedVersion,\n ir: hydratedIr,\n options: hydratedOptions,\n }\n}\n\nexport function validatePluginInput(input: unknown, path = \"PluginInput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.ir === undefined || obj.ir === null) {\n return `${path}.ir: required field is missing`;\n }\n {\n const err = validateIrSchema(obj.ir, `${path}.ir`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginOutput PluginOutput represents the response payload returned by the `plugin` function.\n * \n * After processing the input schema, the plugin outputs this object containing\n * all files to be generated or errors to be displayed to the user.\n * \n * If there are no errors and at least one file is returned, VDL will write each\n * file to the specified path within the output directory. If there are errors,\n * VDL will display them to the user and not write any files.\n */\nexport type PluginOutput = {\n files?: PluginOutputFile[]\n errors?: PluginOutputError[]\n}\n\nexport function hydratePluginOutput(input: PluginOutput): PluginOutput {\n const hydratedFiles = input.files ? input.files.map(el => hydratePluginOutputFile(el)) : input.files\n const hydratedErrors = input.errors ? input.errors.map(el => hydratePluginOutputError(el)) : input.errors\n return {\n files: hydratedFiles,\n errors: hydratedErrors,\n }\n}\n\nexport function validatePluginOutput(input: unknown, path = \"PluginOutput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.files !== undefined && obj.files !== null) {\n {\n if (!Array.isArray(obj.files)) {\n return `${path}.files: expected array, got ${typeof obj.files}`;\n }\n for (let i = 0; i < obj.files.length; i++) {\n {\n const err = validatePluginOutputFile(obj.files[i], `${path}.files[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.errors !== undefined && obj.errors !== null) {\n {\n if (!Array.isArray(obj.errors)) {\n return `${path}.errors: expected array, got ${typeof obj.errors}`;\n }\n for (let i = 0; i < obj.errors.length; i++) {\n {\n const err = validatePluginOutputError(obj.errors[i], `${path}.errors[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * PluginOutputError A structured error reported by the plugin.\n */\nexport type PluginOutputError = {\n message: string\n position?: Position\n}\n\nexport function hydratePluginOutputError(input: PluginOutputError): PluginOutputError {\n const hydratedMessage = input.message\n const hydratedPosition = input.position ? hydratePosition(input.position) : input.position\n return {\n message: hydratedMessage,\n position: hydratedPosition,\n }\n}\n\nexport function validatePluginOutputError(input: unknown, path = \"PluginOutputError\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position !== undefined && obj.position !== null) {\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * PluginOutputFile PluginOutputFile represents a single generated file produced by the plugin.\n * \n * This abstraction allows plugins to generate multiple files from a single\n * invocation, enabling patterns like one-file-per-type or splitting large\n * outputs across multiple modules.\n */\nexport type PluginOutputFile = {\n path: string\n content: string\n}\n\nexport function hydratePluginOutputFile(input: PluginOutputFile): PluginOutputFile {\n const hydratedPath = input.path\n const hydratedContent = input.content\n return {\n path: hydratedPath,\n content: hydratedContent,\n }\n}\n\nexport function validatePluginOutputFile(_input: unknown, _path = \"PluginOutputFile\"): string | null {\n return null;\n}\n\n/**\n * Position It represents a position within a file and is used for error\n * reporting, diagnostics, plugins, and tooling support.\n */\nexport type Position = {\n file: string\n line: number\n column: number\n}\n\nexport function hydratePosition(input: Position): Position {\n const hydratedFile = input.file\n const hydratedLine = input.line\n const hydratedColumn = input.column\n return {\n file: hydratedFile,\n line: hydratedLine,\n column: hydratedColumn,\n }\n}\n\nexport function validatePosition(_input: unknown, _path = \"Position\"): string | null {\n return null;\n}\n\n/**\n * TopLevelDoc Standalone documentation block.\n * \n * Used for top-level docstrings that are not attached to a type/enum/constant.\n */\nexport type TopLevelDoc = {\n position: Position\n content: string\n}\n\nexport function hydrateTopLevelDoc(input: TopLevelDoc): TopLevelDoc {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedContent = input.content\n return {\n position: hydratedPosition,\n content: hydratedContent,\n }\n}\n\nexport function validateTopLevelDoc(input: unknown, path = \"TopLevelDoc\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeDef Flattened type definition.\n * \n * All spreads are already expanded. The unified `typeRef` describes what this\n * type IS, a primitive, custom reference, map, array, or object with fields.\n */\nexport type TypeDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateTypeDef(input: TypeDef): TypeDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateTypeDef(input: unknown, path = \"TypeDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeRef Normalized type reference used by fields and constants.\n * \n * `kind` selects which payload fields are meaningful. Generators should inspect\n * `kind` first, then read the related payload fields.\n */\nexport type TypeRef = {\n kind: TypeKind\n primitiveName?: PrimitiveType\n typeName?: string\n enumName?: string\n enumType?: EnumValueType\n arrayType?: TypeRef\n arrayDims?: number\n mapType?: TypeRef\n objectFields?: Field[]\n}\n\nexport function hydrateTypeRef(input: TypeRef): TypeRef {\n const hydratedKind = input.kind\n const hydratedPrimitiveName = input.primitiveName ? input.primitiveName : input.primitiveName\n const hydratedTypeName = input.typeName ? input.typeName : input.typeName\n const hydratedEnumName = input.enumName ? input.enumName : input.enumName\n const hydratedEnumType = input.enumType ? input.enumType : input.enumType\n const hydratedArrayType = input.arrayType ? hydrateTypeRef(input.arrayType) : input.arrayType\n const hydratedArrayDims = input.arrayDims ? input.arrayDims : input.arrayDims\n const hydratedMapType = input.mapType ? hydrateTypeRef(input.mapType) : input.mapType\n const hydratedObjectFields = input.objectFields ? input.objectFields.map(el => hydrateField(el)) : input.objectFields\n return {\n kind: hydratedKind,\n primitiveName: hydratedPrimitiveName,\n typeName: hydratedTypeName,\n enumName: hydratedEnumName,\n enumType: hydratedEnumType,\n arrayType: hydratedArrayType,\n arrayDims: hydratedArrayDims,\n mapType: hydratedMapType,\n objectFields: hydratedObjectFields,\n }\n}\n\nexport function validateTypeRef(input: unknown, path = \"TypeRef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isTypeKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for TypeKind`;\n }\n }\n if (obj.primitiveName !== undefined && obj.primitiveName !== null) {\n {\n if (!isPrimitiveType(obj.primitiveName)) {\n return `${path}.primitiveName: invalid enum value '${obj.primitiveName}' for PrimitiveType`;\n }\n }\n }\n if (obj.enumType !== undefined && obj.enumType !== null) {\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n }\n if (obj.arrayType !== undefined && obj.arrayType !== null) {\n {\n const err = validateTypeRef(obj.arrayType, `${path}.arrayType`);\n if (err !== null) return err;\n }\n }\n if (obj.mapType !== undefined && obj.mapType !== null) {\n {\n const err = validateTypeRef(obj.mapType, `${path}.mapType`);\n if (err !== null) return err;\n }\n }\n if (obj.objectFields !== undefined && obj.objectFields !== null) {\n {\n if (!Array.isArray(obj.objectFields)) {\n return `${path}.objectFields: expected array, got ${typeof obj.objectFields}`;\n }\n for (let i = 0; i < obj.objectFields.length; i++) {\n {\n const err = validateField(obj.objectFields[i], `${path}.objectFields[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n","import type { Annotation, LiteralValue } from \"../types\";\n\n/**\n * Returns the first annotation that matches the provided name.\n */\nexport function getAnnotation(\n annotations: Annotation[] | undefined,\n name: string,\n): Annotation | undefined {\n if (!annotations) return undefined;\n return annotations.find((anno) => anno.name === name);\n}\n\n/**\n * Returns the raw literal argument stored in an annotation.\n *\n * VDL annotations currently expose a single literal argument.\n * Pair this helper with `unwrapLiteral` when you need a plain JavaScript value.\n */\nexport function getAnnotationArgs(\n annotations: Annotation[] | undefined,\n name: string,\n): LiteralValue | undefined {\n const anno = getAnnotation(annotations, name);\n return anno?.argument;\n}\n","import type { LiteralValue } from \"../types\";\n\n/**\n * Native JavaScript value produced by `unwrapLiteral`.\n *\n * `undefined` is preserved when a literal is missing its kind-specific payload.\n * `null` is returned for unknown literal kinds to keep the resolver non-throwing.\n */\nexport type UnwrappedLiteral =\n | string\n | number\n | boolean\n | null\n | undefined\n | UnwrappedLiteral[]\n | { [key: string]: UnwrappedLiteral };\n\n/**\n * Resolves a `LiteralValue` into its native JavaScript representation.\n *\n * Pass a generic when you already know the expected shape.\n * Omit it to get `unknown` and narrow the result yourself.\n *\n * The generic only affects TypeScript types. It does not validate the runtime value.\n */\nexport function unwrapLiteral<T = unknown>(value: LiteralValue): T {\n return unwrapLiteralValue(value) as T;\n}\n\n/**\n * Performs the recursive literal resolution used by `unwrapLiteral`.\n */\nfunction unwrapLiteralValue(value: LiteralValue): UnwrappedLiteral {\n switch (value.kind) {\n case \"string\":\n return value.stringValue;\n case \"int\":\n return value.intValue;\n case \"float\":\n return value.floatValue;\n case \"bool\":\n return value.boolValue;\n case \"object\": {\n const resolvedObject: { [key: string]: UnwrappedLiteral } = {};\n const entries = value.objectEntries ?? [];\n\n for (const entry of entries) {\n resolvedObject[entry.key] = unwrapLiteralValue(entry.value);\n }\n\n return resolvedObject;\n }\n case \"array\": {\n const items = value.arrayItems ?? [];\n return items.map((item) => unwrapLiteralValue(item));\n }\n default:\n return null;\n }\n}\n","/**\n * Returns a string option or the provided fallback when the key is missing.\n */\nexport function getOptionString(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: string,\n): string {\n const value = options?.[key];\n return value === undefined ? defaultValue : value;\n}\n\n/**\n * Returns a boolean option using common truthy and falsy string values.\n *\n * Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.\n *\n * Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.\n *\n * Invalid values fall back to the provided default.\n */\nexport function getOptionBool(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: boolean,\n): boolean {\n const value = options?.[key];\n\n if (value === undefined) {\n return defaultValue;\n }\n\n switch (value.trim().toLowerCase()) {\n case \"true\":\n case \"1\":\n case \"yes\":\n case \"on\":\n case \"enable\":\n case \"enabled\":\n case \"y\":\n return true;\n case \"false\":\n case \"0\":\n case \"no\":\n case \"off\":\n case \"disable\":\n case \"disabled\":\n case \"n\":\n return false;\n default:\n return defaultValue;\n }\n}\n\n/**\n * Returns a numeric option or the provided fallback when parsing fails.\n *\n * Empty, invalid, and non-finite values fall back to the default.\n */\nexport function getOptionNumber(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: number,\n): number {\n const value = options?.[key];\n\n if (value === undefined) {\n return defaultValue;\n }\n\n const trimmedValue = value.trim();\n\n if (trimmedValue === \"\") {\n return defaultValue;\n }\n\n const parsedValue = Number(trimmedValue);\n return Number.isFinite(parsedValue) ? parsedValue : defaultValue;\n}\n\n/**\n * Returns a string array option from a separator-delimited value.\n *\n * Empty items are removed and each entry is trimmed.\n *\n * Missing values return the provided default.\n *\n * @example\n * // For options: { \"features\": \"feature1, feature2, feature3\" }\n * getOptionArray(options, \"features\", [], \",\")\n * // returns [\"feature1\", \"feature2\", \"feature3\"]\n */\nexport function getOptionArray(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: string[] = [],\n separator = \",\",\n): string[] {\n const value = options?.[key];\n\n if (value === undefined) {\n return defaultValue;\n }\n\n const trimmedValue = value.trim();\n\n if (trimmedValue === \"\") {\n return [];\n }\n\n return trimmedValue\n .split(separator)\n .map((item) => item.trim())\n .filter((item) => item.length > 0);\n}\n"],"mappings":"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"}
|
package/dist/index.d.cts
CHANGED
|
@@ -334,5 +334,40 @@ type UnwrappedLiteral = string | number | boolean | null | undefined | Unwrapped
|
|
|
334
334
|
*/
|
|
335
335
|
declare function unwrapLiteral<T = unknown>(value: LiteralValue): T;
|
|
336
336
|
//#endregion
|
|
337
|
-
|
|
337
|
+
//#region src/utils/options.d.ts
|
|
338
|
+
/**
|
|
339
|
+
* Returns a string option or the provided fallback when the key is missing.
|
|
340
|
+
*/
|
|
341
|
+
declare function getOptionString(options: Record<string, string> | undefined, key: string, defaultValue: string): string;
|
|
342
|
+
/**
|
|
343
|
+
* Returns a boolean option using common truthy and falsy string values.
|
|
344
|
+
*
|
|
345
|
+
* Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.
|
|
346
|
+
*
|
|
347
|
+
* Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.
|
|
348
|
+
*
|
|
349
|
+
* Invalid values fall back to the provided default.
|
|
350
|
+
*/
|
|
351
|
+
declare function getOptionBool(options: Record<string, string> | undefined, key: string, defaultValue: boolean): boolean;
|
|
352
|
+
/**
|
|
353
|
+
* Returns a numeric option or the provided fallback when parsing fails.
|
|
354
|
+
*
|
|
355
|
+
* Empty, invalid, and non-finite values fall back to the default.
|
|
356
|
+
*/
|
|
357
|
+
declare function getOptionNumber(options: Record<string, string> | undefined, key: string, defaultValue: number): number;
|
|
358
|
+
/**
|
|
359
|
+
* Returns a string array option from a separator-delimited value.
|
|
360
|
+
*
|
|
361
|
+
* Empty items are removed and each entry is trimmed.
|
|
362
|
+
*
|
|
363
|
+
* Missing values return the provided default.
|
|
364
|
+
*
|
|
365
|
+
* @example
|
|
366
|
+
* // For options: { "features": "feature1, feature2, feature3" }
|
|
367
|
+
* getOptionArray(options, "features", [], ",")
|
|
368
|
+
* // returns ["feature1", "feature2", "feature3"]
|
|
369
|
+
*/
|
|
370
|
+
declare function getOptionArray(options: Record<string, string> | undefined, key: string, defaultValue?: string[], separator?: string): string[];
|
|
371
|
+
//#endregion
|
|
372
|
+
export { Annotation, ConstantDef, EnumDef, EnumMember, EnumValueType, EnumValueTypeList, Field, IrSchema, LiteralKind, LiteralKindList, LiteralValue, ObjectEntry, PluginInput, PluginOutput, PluginOutputError, PluginOutputFile, Position, PrimitiveType, PrimitiveTypeList, TopLevelDoc, TypeDef, TypeKind, TypeKindList, TypeRef, UnwrappedLiteral, VdlPluginHandler, definePlugin, getAnnotation, getAnnotationArgs, getOptionArray, getOptionBool, getOptionNumber, getOptionString, hydrateAnnotation, hydrateConstantDef, hydrateEnumDef, hydrateEnumMember, hydrateField, hydrateIrSchema, hydrateLiteralValue, hydrateObjectEntry, hydratePluginInput, hydratePluginOutput, hydratePluginOutputError, hydratePluginOutputFile, hydratePosition, hydrateTopLevelDoc, hydrateTypeDef, hydrateTypeRef, isEnumValueType, isLiteralKind, isPrimitiveType, isTypeKind, unwrapLiteral, validateAnnotation, validateConstantDef, validateEnumDef, validateEnumMember, validateField, validateIrSchema, validateLiteralValue, validateObjectEntry, validatePluginInput, validatePluginOutput, validatePluginOutputError, validatePluginOutputFile, validatePosition, validateTopLevelDoc, validateTypeDef, validateTypeRef };
|
|
338
373
|
//# sourceMappingURL=index.d.cts.map
|
package/dist/index.d.cts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/runtime.ts","../src/types/types.ts","../src/define-plugin.ts","../src/utils/annotations.ts","../src/utils/literals.ts"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.d.cts","names":[],"sources":["../src/runtime.ts","../src/types/types.ts","../src/define-plugin.ts","../src/utils/annotations.ts","../src/utils/literals.ts","../src/utils/options.ts"],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -334,5 +334,40 @@ type UnwrappedLiteral = string | number | boolean | null | undefined | Unwrapped
|
|
|
334
334
|
*/
|
|
335
335
|
declare function unwrapLiteral<T = unknown>(value: LiteralValue): T;
|
|
336
336
|
//#endregion
|
|
337
|
-
|
|
337
|
+
//#region src/utils/options.d.ts
|
|
338
|
+
/**
|
|
339
|
+
* Returns a string option or the provided fallback when the key is missing.
|
|
340
|
+
*/
|
|
341
|
+
declare function getOptionString(options: Record<string, string> | undefined, key: string, defaultValue: string): string;
|
|
342
|
+
/**
|
|
343
|
+
* Returns a boolean option using common truthy and falsy string values.
|
|
344
|
+
*
|
|
345
|
+
* Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.
|
|
346
|
+
*
|
|
347
|
+
* Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.
|
|
348
|
+
*
|
|
349
|
+
* Invalid values fall back to the provided default.
|
|
350
|
+
*/
|
|
351
|
+
declare function getOptionBool(options: Record<string, string> | undefined, key: string, defaultValue: boolean): boolean;
|
|
352
|
+
/**
|
|
353
|
+
* Returns a numeric option or the provided fallback when parsing fails.
|
|
354
|
+
*
|
|
355
|
+
* Empty, invalid, and non-finite values fall back to the default.
|
|
356
|
+
*/
|
|
357
|
+
declare function getOptionNumber(options: Record<string, string> | undefined, key: string, defaultValue: number): number;
|
|
358
|
+
/**
|
|
359
|
+
* Returns a string array option from a separator-delimited value.
|
|
360
|
+
*
|
|
361
|
+
* Empty items are removed and each entry is trimmed.
|
|
362
|
+
*
|
|
363
|
+
* Missing values return the provided default.
|
|
364
|
+
*
|
|
365
|
+
* @example
|
|
366
|
+
* // For options: { "features": "feature1, feature2, feature3" }
|
|
367
|
+
* getOptionArray(options, "features", [], ",")
|
|
368
|
+
* // returns ["feature1", "feature2", "feature3"]
|
|
369
|
+
*/
|
|
370
|
+
declare function getOptionArray(options: Record<string, string> | undefined, key: string, defaultValue?: string[], separator?: string): string[];
|
|
371
|
+
//#endregion
|
|
372
|
+
export { Annotation, ConstantDef, EnumDef, EnumMember, EnumValueType, EnumValueTypeList, Field, IrSchema, LiteralKind, LiteralKindList, LiteralValue, ObjectEntry, PluginInput, PluginOutput, PluginOutputError, PluginOutputFile, Position, PrimitiveType, PrimitiveTypeList, TopLevelDoc, TypeDef, TypeKind, TypeKindList, TypeRef, UnwrappedLiteral, VdlPluginHandler, definePlugin, getAnnotation, getAnnotationArgs, getOptionArray, getOptionBool, getOptionNumber, getOptionString, hydrateAnnotation, hydrateConstantDef, hydrateEnumDef, hydrateEnumMember, hydrateField, hydrateIrSchema, hydrateLiteralValue, hydrateObjectEntry, hydratePluginInput, hydratePluginOutput, hydratePluginOutputError, hydratePluginOutputFile, hydratePosition, hydrateTopLevelDoc, hydrateTypeDef, hydrateTypeRef, isEnumValueType, isLiteralKind, isPrimitiveType, isTypeKind, unwrapLiteral, validateAnnotation, validateConstantDef, validateEnumDef, validateEnumMember, validateField, validateIrSchema, validateLiteralValue, validateObjectEntry, validatePluginInput, validatePluginOutput, validatePluginOutputError, validatePluginOutputFile, validatePosition, validateTopLevelDoc, validateTypeDef, validateTypeRef };
|
|
338
373
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","names":[],"sources":["../src/runtime.ts","../src/types/types.ts","../src/define-plugin.ts","../src/utils/annotations.ts","../src/utils/literals.ts"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","names":[],"sources":["../src/runtime.ts","../src/types/types.ts","../src/define-plugin.ts","../src/utils/annotations.ts","../src/utils/literals.ts","../src/utils/options.ts"],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -528,6 +528,77 @@ function unwrapLiteralValue(value) {
|
|
|
528
528
|
}
|
|
529
529
|
}
|
|
530
530
|
//#endregion
|
|
531
|
-
|
|
531
|
+
//#region src/utils/options.ts
|
|
532
|
+
/**
|
|
533
|
+
* Returns a string option or the provided fallback when the key is missing.
|
|
534
|
+
*/
|
|
535
|
+
function getOptionString(options, key, defaultValue) {
|
|
536
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
537
|
+
return value === void 0 ? defaultValue : value;
|
|
538
|
+
}
|
|
539
|
+
/**
|
|
540
|
+
* Returns a boolean option using common truthy and falsy string values.
|
|
541
|
+
*
|
|
542
|
+
* Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.
|
|
543
|
+
*
|
|
544
|
+
* Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.
|
|
545
|
+
*
|
|
546
|
+
* Invalid values fall back to the provided default.
|
|
547
|
+
*/
|
|
548
|
+
function getOptionBool(options, key, defaultValue) {
|
|
549
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
550
|
+
if (value === void 0) return defaultValue;
|
|
551
|
+
switch (value.trim().toLowerCase()) {
|
|
552
|
+
case "true":
|
|
553
|
+
case "1":
|
|
554
|
+
case "yes":
|
|
555
|
+
case "on":
|
|
556
|
+
case "enable":
|
|
557
|
+
case "enabled":
|
|
558
|
+
case "y": return true;
|
|
559
|
+
case "false":
|
|
560
|
+
case "0":
|
|
561
|
+
case "no":
|
|
562
|
+
case "off":
|
|
563
|
+
case "disable":
|
|
564
|
+
case "disabled":
|
|
565
|
+
case "n": return false;
|
|
566
|
+
default: return defaultValue;
|
|
567
|
+
}
|
|
568
|
+
}
|
|
569
|
+
/**
|
|
570
|
+
* Returns a numeric option or the provided fallback when parsing fails.
|
|
571
|
+
*
|
|
572
|
+
* Empty, invalid, and non-finite values fall back to the default.
|
|
573
|
+
*/
|
|
574
|
+
function getOptionNumber(options, key, defaultValue) {
|
|
575
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
576
|
+
if (value === void 0) return defaultValue;
|
|
577
|
+
const trimmedValue = value.trim();
|
|
578
|
+
if (trimmedValue === "") return defaultValue;
|
|
579
|
+
const parsedValue = Number(trimmedValue);
|
|
580
|
+
return Number.isFinite(parsedValue) ? parsedValue : defaultValue;
|
|
581
|
+
}
|
|
582
|
+
/**
|
|
583
|
+
* Returns a string array option from a separator-delimited value.
|
|
584
|
+
*
|
|
585
|
+
* Empty items are removed and each entry is trimmed.
|
|
586
|
+
*
|
|
587
|
+
* Missing values return the provided default.
|
|
588
|
+
*
|
|
589
|
+
* @example
|
|
590
|
+
* // For options: { "features": "feature1, feature2, feature3" }
|
|
591
|
+
* getOptionArray(options, "features", [], ",")
|
|
592
|
+
* // returns ["feature1", "feature2", "feature3"]
|
|
593
|
+
*/
|
|
594
|
+
function getOptionArray(options, key, defaultValue = [], separator = ",") {
|
|
595
|
+
const value = options === null || options === void 0 ? void 0 : options[key];
|
|
596
|
+
if (value === void 0) return defaultValue;
|
|
597
|
+
const trimmedValue = value.trim();
|
|
598
|
+
if (trimmedValue === "") return [];
|
|
599
|
+
return trimmedValue.split(separator).map((item) => item.trim()).filter((item) => item.length > 0);
|
|
600
|
+
}
|
|
601
|
+
//#endregion
|
|
602
|
+
export { EnumValueTypeList, LiteralKindList, PrimitiveTypeList, TypeKindList, definePlugin, getAnnotation, getAnnotationArgs, getOptionArray, getOptionBool, getOptionNumber, getOptionString, hydrateAnnotation, hydrateConstantDef, hydrateEnumDef, hydrateEnumMember, hydrateField, hydrateIrSchema, hydrateLiteralValue, hydrateObjectEntry, hydratePluginInput, hydratePluginOutput, hydratePluginOutputError, hydratePluginOutputFile, hydratePosition, hydrateTopLevelDoc, hydrateTypeDef, hydrateTypeRef, isEnumValueType, isLiteralKind, isPrimitiveType, isTypeKind, unwrapLiteral, validateAnnotation, validateConstantDef, validateEnumDef, validateEnumMember, validateField, validateIrSchema, validateLiteralValue, validateObjectEntry, validatePluginInput, validatePluginOutput, validatePluginOutputError, validatePluginOutputFile, validatePosition, validateTopLevelDoc, validateTypeDef, validateTypeRef };
|
|
532
603
|
|
|
533
604
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../src/define-plugin.ts","../src/types/types.ts","../src/utils/annotations.ts","../src/utils/literals.ts"],"sourcesContent":["import type { PluginInput, PluginOutput } from \"./types\";\n\n/**\n * Defines a VDL plugin handler function.\n *\n * @param input - The input data for the plugin containing the IR and other relevant information.\n * @returns The output data from the plugin containing the generated files and any errors.\n */\nexport type VdlPluginHandler = (input: PluginInput) => PluginOutput;\n\n/**\n * Defines a VDL plugin by wrapping the provided handler function. This is a helper function\n * that can be used to create plugins in a more concise way.\n *\n * Example usage:\n * ```typescript\n * import { definePlugin } from \"@varavel/vdl-plugin-sdk\";\n *\n * export const generate = definePlugin((input) => {\n * // Plugin logic goes here\n * return {\n * files: [],\n * errors: []\n * };\n * });\n * ```\n *\n * @param handler - The plugin handler function that contains the logic for processing the input and generating the output.\n * @returns The same handler function, which can be exported as the plugin's main entry point.\n */\nexport function definePlugin(handler: VdlPluginHandler): VdlPluginHandler {\n return handler;\n}\n","// Code generated by VDL v0.4.0-alpha.5. DO NOT EDIT.\n// If you edit this file, it will be overwritten the next time it is generated.\n//\n// For more information about VDL, visit https://vdl.varavel.com\n\n/* eslint-disable */\n/* tslint:disable */\n// biome-ignore-all lint: Generated by VDL\n\n// -----------------------------------------------------------------------------\n// Enumerations\n// -----------------------------------------------------------------------------\n\n/**\n * Underlying storage kind used by an enum\n */\nexport type EnumValueType = \"string\" | \"int\";\n\nexport const EnumValueTypeList: EnumValueType[] = [\n \"string\",\n \"int\",\n];\n\nexport function isEnumValueType(value: unknown): value is EnumValueType {\n return EnumValueTypeList.includes(value as EnumValueType);\n}\n\n/**\n * Kind discriminator for LiteralValue.\n * \n * LiteralValue is used for fully resolved literal data in:\n * \n * - constant values\n * - annotation arguments\n */\nexport type LiteralKind = \"string\" | \"int\" | \"float\" | \"bool\" | \"object\" | \"array\";\n\nexport const LiteralKindList: LiteralKind[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"object\",\n \"array\",\n];\n\nexport function isLiteralKind(value: unknown): value is LiteralKind {\n return LiteralKindList.includes(value as LiteralKind);\n}\n\n/**\n * Primitive scalar type names\n */\nexport type PrimitiveType = \"string\" | \"int\" | \"float\" | \"bool\" | \"datetime\";\n\nexport const PrimitiveTypeList: PrimitiveType[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"datetime\",\n];\n\nexport function isPrimitiveType(value: unknown): value is PrimitiveType {\n return PrimitiveTypeList.includes(value as PrimitiveType);\n}\n\n/**\n * Kind discriminator for TypeRef\n */\nexport type TypeKind = \"primitive\" | \"type\" | \"enum\" | \"array\" | \"map\" | \"object\";\n\nexport const TypeKindList: TypeKind[] = [\n \"primitive\",\n \"type\",\n \"enum\",\n \"array\",\n \"map\",\n \"object\",\n];\n\nexport function isTypeKind(value: unknown): value is TypeKind {\n return TypeKindList.includes(value as TypeKind);\n}\n\n// -----------------------------------------------------------------------------\n// Domain Types\n// -----------------------------------------------------------------------------\n\n/**\n * Annotation Annotation metadata preserved in IR.\n * \n * `name` is the annotation identifier without the `@` prefix.\n * `argument`, when present, is fully resolved as a LiteralValue.\n */\nexport type Annotation = {\n position: Position\n name: string\n argument?: LiteralValue\n}\n\nexport function hydrateAnnotation(input: Annotation): Annotation {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedArgument = input.argument ? hydrateLiteralValue(input.argument) : input.argument\n return {\n position: hydratedPosition,\n name: hydratedName,\n argument: hydratedArgument,\n }\n}\n\nexport function validateAnnotation(input: unknown, path = \"Annotation\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.argument !== undefined && obj.argument !== null) {\n {\n const err = validateLiteralValue(obj.argument, `${path}.argument`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * ConstantDef Fully resolved constant definition.\n * \n * `typeRef` is explicit or inferred by analysis.\n * `value` contains the fully resolved literal payload.\n */\nexport type ConstantDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n value: LiteralValue\n}\n\nexport function hydrateConstantDef(input: ConstantDef): ConstantDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n value: hydratedValue,\n }\n}\n\nexport function validateConstantDef(input: unknown, path = \"ConstantDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * EnumDef Flattened enum definition.\n * \n * All enum spreads are already expanded into `members`.\n */\nexport type EnumDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n enumType: EnumValueType\n members: EnumMember[]\n}\n\nexport function hydrateEnumDef(input: EnumDef): EnumDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedEnumType = input.enumType\n const hydratedMembers = input.members.map(el => hydrateEnumMember(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n enumType: hydratedEnumType,\n members: hydratedMembers,\n }\n}\n\nexport function validateEnumDef(input: unknown, path = \"EnumDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enumType === undefined || obj.enumType === null) {\n return `${path}.enumType: required field is missing`;\n }\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n if (obj.members === undefined || obj.members === null) {\n return `${path}.members: required field is missing`;\n }\n {\n if (!Array.isArray(obj.members)) {\n return `${path}.members: expected array, got ${typeof obj.members}`;\n }\n for (let i = 0; i < obj.members.length; i++) {\n {\n const err = validateEnumMember(obj.members[i], `${path}.members[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * EnumMember Enum member definition\n */\nexport type EnumMember = {\n position: Position\n name: string\n value: LiteralValue\n doc?: string\n annotations: Annotation[]\n}\n\nexport function hydrateEnumMember(input: EnumMember): EnumMember {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedValue = hydrateLiteralValue(input.value)\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n value: hydratedValue,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n }\n}\n\nexport function validateEnumMember(input: unknown, path = \"EnumMember\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * Field Flattened object/type field definition\n */\nexport type Field = {\n position: Position\n name: string\n doc?: string\n optional: boolean\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateField(input: Field): Field {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedOptional = input.optional\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n optional: hydratedOptional,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateField(input: unknown, path = \"Field\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * IrSchema IrSchema is the generator-facing representation of a VDL program.\n * \n * This model is intentionally \"flat\" and \"resolved\":\n * \n * - spreads are already expanded\n * - references are already resolved\n * - collections are in deterministic order\n * \n * A code generator should be able to consume IrSchema directly, without needing\n * to re-run parser or semantic-analysis logic.\n */\nexport type IrSchema = {\n entryPoint: string\n constants: ConstantDef[]\n enums: EnumDef[]\n types: TypeDef[]\n docs: TopLevelDoc[]\n}\n\nexport function hydrateIrSchema(input: IrSchema): IrSchema {\n const hydratedEntryPoint = input.entryPoint\n const hydratedConstants = input.constants.map(el => hydrateConstantDef(el))\n const hydratedEnums = input.enums.map(el => hydrateEnumDef(el))\n const hydratedTypes = input.types.map(el => hydrateTypeDef(el))\n const hydratedDocs = input.docs.map(el => hydrateTopLevelDoc(el))\n return {\n entryPoint: hydratedEntryPoint,\n constants: hydratedConstants,\n enums: hydratedEnums,\n types: hydratedTypes,\n docs: hydratedDocs,\n }\n}\n\nexport function validateIrSchema(input: unknown, path = \"IrSchema\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.constants === undefined || obj.constants === null) {\n return `${path}.constants: required field is missing`;\n }\n {\n if (!Array.isArray(obj.constants)) {\n return `${path}.constants: expected array, got ${typeof obj.constants}`;\n }\n for (let i = 0; i < obj.constants.length; i++) {\n {\n const err = validateConstantDef(obj.constants[i], `${path}.constants[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enums === undefined || obj.enums === null) {\n return `${path}.enums: required field is missing`;\n }\n {\n if (!Array.isArray(obj.enums)) {\n return `${path}.enums: expected array, got ${typeof obj.enums}`;\n }\n for (let i = 0; i < obj.enums.length; i++) {\n {\n const err = validateEnumDef(obj.enums[i], `${path}.enums[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.types === undefined || obj.types === null) {\n return `${path}.types: required field is missing`;\n }\n {\n if (!Array.isArray(obj.types)) {\n return `${path}.types: expected array, got ${typeof obj.types}`;\n }\n for (let i = 0; i < obj.types.length; i++) {\n {\n const err = validateTypeDef(obj.types[i], `${path}.types[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.docs === undefined || obj.docs === null) {\n return `${path}.docs: required field is missing`;\n }\n {\n if (!Array.isArray(obj.docs)) {\n return `${path}.docs: expected array, got ${typeof obj.docs}`;\n }\n for (let i = 0; i < obj.docs.length; i++) {\n {\n const err = validateTopLevelDoc(obj.docs[i], `${path}.docs[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * LiteralValue Fully resolved literal value.\n * \n * The selected payload is determined by `kind`:\n * \n * - `string` -> `stringValue`\n * - `int` -> `intValue`\n * - `float` -> `floatValue`\n * - `bool` -> `boolValue`\n * - `object` -> `objectEntries`\n * - `array` -> `arrayItems`\n */\nexport type LiteralValue = {\n position: Position\n kind: LiteralKind\n stringValue?: string\n intValue?: number\n floatValue?: number\n boolValue?: boolean\n objectEntries?: ObjectEntry[]\n arrayItems?: LiteralValue[]\n}\n\nexport function hydrateLiteralValue(input: LiteralValue): LiteralValue {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKind = input.kind\n const hydratedStringValue = input.stringValue ? input.stringValue : input.stringValue\n const hydratedIntValue = input.intValue ? input.intValue : input.intValue\n const hydratedFloatValue = input.floatValue ? input.floatValue : input.floatValue\n const hydratedBoolValue = input.boolValue ? input.boolValue : input.boolValue\n const hydratedObjectEntries = input.objectEntries ? input.objectEntries.map(el => hydrateObjectEntry(el)) : input.objectEntries\n const hydratedArrayItems = input.arrayItems ? input.arrayItems.map(el => hydrateLiteralValue(el)) : input.arrayItems\n return {\n position: hydratedPosition,\n kind: hydratedKind,\n stringValue: hydratedStringValue,\n intValue: hydratedIntValue,\n floatValue: hydratedFloatValue,\n boolValue: hydratedBoolValue,\n objectEntries: hydratedObjectEntries,\n arrayItems: hydratedArrayItems,\n }\n}\n\nexport function validateLiteralValue(input: unknown, path = \"LiteralValue\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isLiteralKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for LiteralKind`;\n }\n }\n if (obj.objectEntries !== undefined && obj.objectEntries !== null) {\n {\n if (!Array.isArray(obj.objectEntries)) {\n return `${path}.objectEntries: expected array, got ${typeof obj.objectEntries}`;\n }\n for (let i = 0; i < obj.objectEntries.length; i++) {\n {\n const err = validateObjectEntry(obj.objectEntries[i], `${path}.objectEntries[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.arrayItems !== undefined && obj.arrayItems !== null) {\n {\n if (!Array.isArray(obj.arrayItems)) {\n return `${path}.arrayItems: expected array, got ${typeof obj.arrayItems}`;\n }\n for (let i = 0; i < obj.arrayItems.length; i++) {\n {\n const err = validateLiteralValue(obj.arrayItems[i], `${path}.arrayItems[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * ObjectEntry Key/value pair inside an object LiteralValue payload\n */\nexport type ObjectEntry = {\n position: Position\n key: string\n value: LiteralValue\n}\n\nexport function hydrateObjectEntry(input: ObjectEntry): ObjectEntry {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKey = input.key\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n key: hydratedKey,\n value: hydratedValue,\n }\n}\n\nexport function validateObjectEntry(input: unknown, path = \"ObjectEntry\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginInput PluginInput represents the data payload sent to a plugin.\n * \n * The plugin receives this as a single argument containing the complete\n * Intermediate Representation of the VDL schema along with any user-defined\n * configuration options from `vdl.config.vdl`.\n */\nexport type PluginInput = {\n version: string\n ir: IrSchema\n options: Record<string, string>\n}\n\nexport function hydratePluginInput(input: PluginInput): PluginInput {\n const hydratedVersion = input.version\n const hydratedIr = hydrateIrSchema(input.ir)\n const hydratedOptions = input.options\n return {\n version: hydratedVersion,\n ir: hydratedIr,\n options: hydratedOptions,\n }\n}\n\nexport function validatePluginInput(input: unknown, path = \"PluginInput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.ir === undefined || obj.ir === null) {\n return `${path}.ir: required field is missing`;\n }\n {\n const err = validateIrSchema(obj.ir, `${path}.ir`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginOutput PluginOutput represents the response payload returned by the `plugin` function.\n * \n * After processing the input schema, the plugin outputs this object containing\n * all files to be generated or errors to be displayed to the user.\n * \n * If there are no errors and at least one file is returned, VDL will write each\n * file to the specified path within the output directory. If there are errors,\n * VDL will display them to the user and not write any files.\n */\nexport type PluginOutput = {\n files?: PluginOutputFile[]\n errors?: PluginOutputError[]\n}\n\nexport function hydratePluginOutput(input: PluginOutput): PluginOutput {\n const hydratedFiles = input.files ? input.files.map(el => hydratePluginOutputFile(el)) : input.files\n const hydratedErrors = input.errors ? input.errors.map(el => hydratePluginOutputError(el)) : input.errors\n return {\n files: hydratedFiles,\n errors: hydratedErrors,\n }\n}\n\nexport function validatePluginOutput(input: unknown, path = \"PluginOutput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.files !== undefined && obj.files !== null) {\n {\n if (!Array.isArray(obj.files)) {\n return `${path}.files: expected array, got ${typeof obj.files}`;\n }\n for (let i = 0; i < obj.files.length; i++) {\n {\n const err = validatePluginOutputFile(obj.files[i], `${path}.files[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.errors !== undefined && obj.errors !== null) {\n {\n if (!Array.isArray(obj.errors)) {\n return `${path}.errors: expected array, got ${typeof obj.errors}`;\n }\n for (let i = 0; i < obj.errors.length; i++) {\n {\n const err = validatePluginOutputError(obj.errors[i], `${path}.errors[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * PluginOutputError A structured error reported by the plugin.\n */\nexport type PluginOutputError = {\n message: string\n position?: Position\n}\n\nexport function hydratePluginOutputError(input: PluginOutputError): PluginOutputError {\n const hydratedMessage = input.message\n const hydratedPosition = input.position ? hydratePosition(input.position) : input.position\n return {\n message: hydratedMessage,\n position: hydratedPosition,\n }\n}\n\nexport function validatePluginOutputError(input: unknown, path = \"PluginOutputError\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position !== undefined && obj.position !== null) {\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * PluginOutputFile PluginOutputFile represents a single generated file produced by the plugin.\n * \n * This abstraction allows plugins to generate multiple files from a single\n * invocation, enabling patterns like one-file-per-type or splitting large\n * outputs across multiple modules.\n */\nexport type PluginOutputFile = {\n path: string\n content: string\n}\n\nexport function hydratePluginOutputFile(input: PluginOutputFile): PluginOutputFile {\n const hydratedPath = input.path\n const hydratedContent = input.content\n return {\n path: hydratedPath,\n content: hydratedContent,\n }\n}\n\nexport function validatePluginOutputFile(_input: unknown, _path = \"PluginOutputFile\"): string | null {\n return null;\n}\n\n/**\n * Position It represents a position within a file and is used for error\n * reporting, diagnostics, plugins, and tooling support.\n */\nexport type Position = {\n file: string\n line: number\n column: number\n}\n\nexport function hydratePosition(input: Position): Position {\n const hydratedFile = input.file\n const hydratedLine = input.line\n const hydratedColumn = input.column\n return {\n file: hydratedFile,\n line: hydratedLine,\n column: hydratedColumn,\n }\n}\n\nexport function validatePosition(_input: unknown, _path = \"Position\"): string | null {\n return null;\n}\n\n/**\n * TopLevelDoc Standalone documentation block.\n * \n * Used for top-level docstrings that are not attached to a type/enum/constant.\n */\nexport type TopLevelDoc = {\n position: Position\n content: string\n}\n\nexport function hydrateTopLevelDoc(input: TopLevelDoc): TopLevelDoc {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedContent = input.content\n return {\n position: hydratedPosition,\n content: hydratedContent,\n }\n}\n\nexport function validateTopLevelDoc(input: unknown, path = \"TopLevelDoc\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeDef Flattened type definition.\n * \n * All spreads are already expanded. The unified `typeRef` describes what this\n * type IS, a primitive, custom reference, map, array, or object with fields.\n */\nexport type TypeDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateTypeDef(input: TypeDef): TypeDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateTypeDef(input: unknown, path = \"TypeDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeRef Normalized type reference used by fields and constants.\n * \n * `kind` selects which payload fields are meaningful. Generators should inspect\n * `kind` first, then read the related payload fields.\n */\nexport type TypeRef = {\n kind: TypeKind\n primitiveName?: PrimitiveType\n typeName?: string\n enumName?: string\n enumType?: EnumValueType\n arrayType?: TypeRef\n arrayDims?: number\n mapType?: TypeRef\n objectFields?: Field[]\n}\n\nexport function hydrateTypeRef(input: TypeRef): TypeRef {\n const hydratedKind = input.kind\n const hydratedPrimitiveName = input.primitiveName ? input.primitiveName : input.primitiveName\n const hydratedTypeName = input.typeName ? input.typeName : input.typeName\n const hydratedEnumName = input.enumName ? input.enumName : input.enumName\n const hydratedEnumType = input.enumType ? input.enumType : input.enumType\n const hydratedArrayType = input.arrayType ? hydrateTypeRef(input.arrayType) : input.arrayType\n const hydratedArrayDims = input.arrayDims ? input.arrayDims : input.arrayDims\n const hydratedMapType = input.mapType ? hydrateTypeRef(input.mapType) : input.mapType\n const hydratedObjectFields = input.objectFields ? input.objectFields.map(el => hydrateField(el)) : input.objectFields\n return {\n kind: hydratedKind,\n primitiveName: hydratedPrimitiveName,\n typeName: hydratedTypeName,\n enumName: hydratedEnumName,\n enumType: hydratedEnumType,\n arrayType: hydratedArrayType,\n arrayDims: hydratedArrayDims,\n mapType: hydratedMapType,\n objectFields: hydratedObjectFields,\n }\n}\n\nexport function validateTypeRef(input: unknown, path = \"TypeRef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isTypeKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for TypeKind`;\n }\n }\n if (obj.primitiveName !== undefined && obj.primitiveName !== null) {\n {\n if (!isPrimitiveType(obj.primitiveName)) {\n return `${path}.primitiveName: invalid enum value '${obj.primitiveName}' for PrimitiveType`;\n }\n }\n }\n if (obj.enumType !== undefined && obj.enumType !== null) {\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n }\n if (obj.arrayType !== undefined && obj.arrayType !== null) {\n {\n const err = validateTypeRef(obj.arrayType, `${path}.arrayType`);\n if (err !== null) return err;\n }\n }\n if (obj.mapType !== undefined && obj.mapType !== null) {\n {\n const err = validateTypeRef(obj.mapType, `${path}.mapType`);\n if (err !== null) return err;\n }\n }\n if (obj.objectFields !== undefined && obj.objectFields !== null) {\n {\n if (!Array.isArray(obj.objectFields)) {\n return `${path}.objectFields: expected array, got ${typeof obj.objectFields}`;\n }\n for (let i = 0; i < obj.objectFields.length; i++) {\n {\n const err = validateField(obj.objectFields[i], `${path}.objectFields[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n","import type { Annotation, LiteralValue } from \"../types\";\n\n/**\n * Returns the first annotation that matches the provided name.\n */\nexport function getAnnotation(\n annotations: Annotation[] | undefined,\n name: string,\n): Annotation | undefined {\n if (!annotations) return undefined;\n return annotations.find((anno) => anno.name === name);\n}\n\n/**\n * Returns the raw literal argument stored in an annotation.\n *\n * VDL annotations currently expose a single literal argument.\n * Pair this helper with `unwrapLiteral` when you need a plain JavaScript value.\n */\nexport function getAnnotationArgs(\n annotations: Annotation[] | undefined,\n name: string,\n): LiteralValue | undefined {\n const anno = getAnnotation(annotations, name);\n return anno?.argument;\n}\n","import type { LiteralValue } from \"../types\";\n\n/**\n * Native JavaScript value produced by `unwrapLiteral`.\n *\n * `undefined` is preserved when a literal is missing its kind-specific payload.\n * `null` is returned for unknown literal kinds to keep the resolver non-throwing.\n */\nexport type UnwrappedLiteral =\n | string\n | number\n | boolean\n | null\n | undefined\n | UnwrappedLiteral[]\n | { [key: string]: UnwrappedLiteral };\n\n/**\n * Resolves a `LiteralValue` into its native JavaScript representation.\n *\n * Pass a generic when you already know the expected shape.\n * Omit it to get `unknown` and narrow the result yourself.\n *\n * The generic only affects TypeScript types. It does not validate the runtime value.\n */\nexport function unwrapLiteral<T = unknown>(value: LiteralValue): T {\n return unwrapLiteralValue(value) as T;\n}\n\n/**\n * Performs the recursive literal resolution used by `unwrapLiteral`.\n */\nfunction unwrapLiteralValue(value: LiteralValue): UnwrappedLiteral {\n switch (value.kind) {\n case \"string\":\n return value.stringValue;\n case \"int\":\n return value.intValue;\n case \"float\":\n return value.floatValue;\n case \"bool\":\n return value.boolValue;\n case \"object\": {\n const resolvedObject: { [key: string]: UnwrappedLiteral } = {};\n const entries = value.objectEntries ?? [];\n\n for (const entry of entries) {\n resolvedObject[entry.key] = unwrapLiteralValue(entry.value);\n }\n\n return resolvedObject;\n }\n case \"array\": {\n const items = value.arrayItems ?? [];\n return items.map((item) => unwrapLiteralValue(item));\n }\n default:\n return null;\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../src/define-plugin.ts","../src/types/types.ts","../src/utils/annotations.ts","../src/utils/literals.ts","../src/utils/options.ts"],"sourcesContent":["import type { PluginInput, PluginOutput } from \"./types\";\n\n/**\n * Defines a VDL plugin handler function.\n *\n * @param input - The input data for the plugin containing the IR and other relevant information.\n * @returns The output data from the plugin containing the generated files and any errors.\n */\nexport type VdlPluginHandler = (input: PluginInput) => PluginOutput;\n\n/**\n * Defines a VDL plugin by wrapping the provided handler function. This is a helper function\n * that can be used to create plugins in a more concise way.\n *\n * Example usage:\n * ```typescript\n * import { definePlugin } from \"@varavel/vdl-plugin-sdk\";\n *\n * export const generate = definePlugin((input) => {\n * // Plugin logic goes here\n * return {\n * files: [],\n * errors: []\n * };\n * });\n * ```\n *\n * @param handler - The plugin handler function that contains the logic for processing the input and generating the output.\n * @returns The same handler function, which can be exported as the plugin's main entry point.\n */\nexport function definePlugin(handler: VdlPluginHandler): VdlPluginHandler {\n return handler;\n}\n","// Code generated by VDL v0.4.0-alpha.5. DO NOT EDIT.\n// If you edit this file, it will be overwritten the next time it is generated.\n//\n// For more information about VDL, visit https://vdl.varavel.com\n\n/* eslint-disable */\n/* tslint:disable */\n// biome-ignore-all lint: Generated by VDL\n\n// -----------------------------------------------------------------------------\n// Enumerations\n// -----------------------------------------------------------------------------\n\n/**\n * Underlying storage kind used by an enum\n */\nexport type EnumValueType = \"string\" | \"int\";\n\nexport const EnumValueTypeList: EnumValueType[] = [\n \"string\",\n \"int\",\n];\n\nexport function isEnumValueType(value: unknown): value is EnumValueType {\n return EnumValueTypeList.includes(value as EnumValueType);\n}\n\n/**\n * Kind discriminator for LiteralValue.\n * \n * LiteralValue is used for fully resolved literal data in:\n * \n * - constant values\n * - annotation arguments\n */\nexport type LiteralKind = \"string\" | \"int\" | \"float\" | \"bool\" | \"object\" | \"array\";\n\nexport const LiteralKindList: LiteralKind[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"object\",\n \"array\",\n];\n\nexport function isLiteralKind(value: unknown): value is LiteralKind {\n return LiteralKindList.includes(value as LiteralKind);\n}\n\n/**\n * Primitive scalar type names\n */\nexport type PrimitiveType = \"string\" | \"int\" | \"float\" | \"bool\" | \"datetime\";\n\nexport const PrimitiveTypeList: PrimitiveType[] = [\n \"string\",\n \"int\",\n \"float\",\n \"bool\",\n \"datetime\",\n];\n\nexport function isPrimitiveType(value: unknown): value is PrimitiveType {\n return PrimitiveTypeList.includes(value as PrimitiveType);\n}\n\n/**\n * Kind discriminator for TypeRef\n */\nexport type TypeKind = \"primitive\" | \"type\" | \"enum\" | \"array\" | \"map\" | \"object\";\n\nexport const TypeKindList: TypeKind[] = [\n \"primitive\",\n \"type\",\n \"enum\",\n \"array\",\n \"map\",\n \"object\",\n];\n\nexport function isTypeKind(value: unknown): value is TypeKind {\n return TypeKindList.includes(value as TypeKind);\n}\n\n// -----------------------------------------------------------------------------\n// Domain Types\n// -----------------------------------------------------------------------------\n\n/**\n * Annotation Annotation metadata preserved in IR.\n * \n * `name` is the annotation identifier without the `@` prefix.\n * `argument`, when present, is fully resolved as a LiteralValue.\n */\nexport type Annotation = {\n position: Position\n name: string\n argument?: LiteralValue\n}\n\nexport function hydrateAnnotation(input: Annotation): Annotation {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedArgument = input.argument ? hydrateLiteralValue(input.argument) : input.argument\n return {\n position: hydratedPosition,\n name: hydratedName,\n argument: hydratedArgument,\n }\n}\n\nexport function validateAnnotation(input: unknown, path = \"Annotation\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.argument !== undefined && obj.argument !== null) {\n {\n const err = validateLiteralValue(obj.argument, `${path}.argument`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * ConstantDef Fully resolved constant definition.\n * \n * `typeRef` is explicit or inferred by analysis.\n * `value` contains the fully resolved literal payload.\n */\nexport type ConstantDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n value: LiteralValue\n}\n\nexport function hydrateConstantDef(input: ConstantDef): ConstantDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n value: hydratedValue,\n }\n}\n\nexport function validateConstantDef(input: unknown, path = \"ConstantDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * EnumDef Flattened enum definition.\n * \n * All enum spreads are already expanded into `members`.\n */\nexport type EnumDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n enumType: EnumValueType\n members: EnumMember[]\n}\n\nexport function hydrateEnumDef(input: EnumDef): EnumDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedEnumType = input.enumType\n const hydratedMembers = input.members.map(el => hydrateEnumMember(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n enumType: hydratedEnumType,\n members: hydratedMembers,\n }\n}\n\nexport function validateEnumDef(input: unknown, path = \"EnumDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enumType === undefined || obj.enumType === null) {\n return `${path}.enumType: required field is missing`;\n }\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n if (obj.members === undefined || obj.members === null) {\n return `${path}.members: required field is missing`;\n }\n {\n if (!Array.isArray(obj.members)) {\n return `${path}.members: expected array, got ${typeof obj.members}`;\n }\n for (let i = 0; i < obj.members.length; i++) {\n {\n const err = validateEnumMember(obj.members[i], `${path}.members[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * EnumMember Enum member definition\n */\nexport type EnumMember = {\n position: Position\n name: string\n value: LiteralValue\n doc?: string\n annotations: Annotation[]\n}\n\nexport function hydrateEnumMember(input: EnumMember): EnumMember {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedValue = hydrateLiteralValue(input.value)\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n return {\n position: hydratedPosition,\n name: hydratedName,\n value: hydratedValue,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n }\n}\n\nexport function validateEnumMember(input: unknown, path = \"EnumMember\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * Field Flattened object/type field definition\n */\nexport type Field = {\n position: Position\n name: string\n doc?: string\n optional: boolean\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateField(input: Field): Field {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedOptional = input.optional\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n optional: hydratedOptional,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateField(input: unknown, path = \"Field\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * IrSchema IrSchema is the generator-facing representation of a VDL program.\n * \n * This model is intentionally \"flat\" and \"resolved\":\n * \n * - spreads are already expanded\n * - references are already resolved\n * - collections are in deterministic order\n * \n * A code generator should be able to consume IrSchema directly, without needing\n * to re-run parser or semantic-analysis logic.\n */\nexport type IrSchema = {\n entryPoint: string\n constants: ConstantDef[]\n enums: EnumDef[]\n types: TypeDef[]\n docs: TopLevelDoc[]\n}\n\nexport function hydrateIrSchema(input: IrSchema): IrSchema {\n const hydratedEntryPoint = input.entryPoint\n const hydratedConstants = input.constants.map(el => hydrateConstantDef(el))\n const hydratedEnums = input.enums.map(el => hydrateEnumDef(el))\n const hydratedTypes = input.types.map(el => hydrateTypeDef(el))\n const hydratedDocs = input.docs.map(el => hydrateTopLevelDoc(el))\n return {\n entryPoint: hydratedEntryPoint,\n constants: hydratedConstants,\n enums: hydratedEnums,\n types: hydratedTypes,\n docs: hydratedDocs,\n }\n}\n\nexport function validateIrSchema(input: unknown, path = \"IrSchema\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.constants === undefined || obj.constants === null) {\n return `${path}.constants: required field is missing`;\n }\n {\n if (!Array.isArray(obj.constants)) {\n return `${path}.constants: expected array, got ${typeof obj.constants}`;\n }\n for (let i = 0; i < obj.constants.length; i++) {\n {\n const err = validateConstantDef(obj.constants[i], `${path}.constants[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.enums === undefined || obj.enums === null) {\n return `${path}.enums: required field is missing`;\n }\n {\n if (!Array.isArray(obj.enums)) {\n return `${path}.enums: expected array, got ${typeof obj.enums}`;\n }\n for (let i = 0; i < obj.enums.length; i++) {\n {\n const err = validateEnumDef(obj.enums[i], `${path}.enums[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.types === undefined || obj.types === null) {\n return `${path}.types: required field is missing`;\n }\n {\n if (!Array.isArray(obj.types)) {\n return `${path}.types: expected array, got ${typeof obj.types}`;\n }\n for (let i = 0; i < obj.types.length; i++) {\n {\n const err = validateTypeDef(obj.types[i], `${path}.types[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.docs === undefined || obj.docs === null) {\n return `${path}.docs: required field is missing`;\n }\n {\n if (!Array.isArray(obj.docs)) {\n return `${path}.docs: expected array, got ${typeof obj.docs}`;\n }\n for (let i = 0; i < obj.docs.length; i++) {\n {\n const err = validateTopLevelDoc(obj.docs[i], `${path}.docs[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n return null;\n}\n\n/**\n * LiteralValue Fully resolved literal value.\n * \n * The selected payload is determined by `kind`:\n * \n * - `string` -> `stringValue`\n * - `int` -> `intValue`\n * - `float` -> `floatValue`\n * - `bool` -> `boolValue`\n * - `object` -> `objectEntries`\n * - `array` -> `arrayItems`\n */\nexport type LiteralValue = {\n position: Position\n kind: LiteralKind\n stringValue?: string\n intValue?: number\n floatValue?: number\n boolValue?: boolean\n objectEntries?: ObjectEntry[]\n arrayItems?: LiteralValue[]\n}\n\nexport function hydrateLiteralValue(input: LiteralValue): LiteralValue {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKind = input.kind\n const hydratedStringValue = input.stringValue ? input.stringValue : input.stringValue\n const hydratedIntValue = input.intValue ? input.intValue : input.intValue\n const hydratedFloatValue = input.floatValue ? input.floatValue : input.floatValue\n const hydratedBoolValue = input.boolValue ? input.boolValue : input.boolValue\n const hydratedObjectEntries = input.objectEntries ? input.objectEntries.map(el => hydrateObjectEntry(el)) : input.objectEntries\n const hydratedArrayItems = input.arrayItems ? input.arrayItems.map(el => hydrateLiteralValue(el)) : input.arrayItems\n return {\n position: hydratedPosition,\n kind: hydratedKind,\n stringValue: hydratedStringValue,\n intValue: hydratedIntValue,\n floatValue: hydratedFloatValue,\n boolValue: hydratedBoolValue,\n objectEntries: hydratedObjectEntries,\n arrayItems: hydratedArrayItems,\n }\n}\n\nexport function validateLiteralValue(input: unknown, path = \"LiteralValue\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isLiteralKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for LiteralKind`;\n }\n }\n if (obj.objectEntries !== undefined && obj.objectEntries !== null) {\n {\n if (!Array.isArray(obj.objectEntries)) {\n return `${path}.objectEntries: expected array, got ${typeof obj.objectEntries}`;\n }\n for (let i = 0; i < obj.objectEntries.length; i++) {\n {\n const err = validateObjectEntry(obj.objectEntries[i], `${path}.objectEntries[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.arrayItems !== undefined && obj.arrayItems !== null) {\n {\n if (!Array.isArray(obj.arrayItems)) {\n return `${path}.arrayItems: expected array, got ${typeof obj.arrayItems}`;\n }\n for (let i = 0; i < obj.arrayItems.length; i++) {\n {\n const err = validateLiteralValue(obj.arrayItems[i], `${path}.arrayItems[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * ObjectEntry Key/value pair inside an object LiteralValue payload\n */\nexport type ObjectEntry = {\n position: Position\n key: string\n value: LiteralValue\n}\n\nexport function hydrateObjectEntry(input: ObjectEntry): ObjectEntry {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedKey = input.key\n const hydratedValue = hydrateLiteralValue(input.value)\n return {\n position: hydratedPosition,\n key: hydratedKey,\n value: hydratedValue,\n }\n}\n\nexport function validateObjectEntry(input: unknown, path = \"ObjectEntry\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.value === undefined || obj.value === null) {\n return `${path}.value: required field is missing`;\n }\n {\n const err = validateLiteralValue(obj.value, `${path}.value`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginInput PluginInput represents the data payload sent to a plugin.\n * \n * The plugin receives this as a single argument containing the complete\n * Intermediate Representation of the VDL schema along with any user-defined\n * configuration options from `vdl.config.vdl`.\n */\nexport type PluginInput = {\n version: string\n ir: IrSchema\n options: Record<string, string>\n}\n\nexport function hydratePluginInput(input: PluginInput): PluginInput {\n const hydratedVersion = input.version\n const hydratedIr = hydrateIrSchema(input.ir)\n const hydratedOptions = input.options\n return {\n version: hydratedVersion,\n ir: hydratedIr,\n options: hydratedOptions,\n }\n}\n\nexport function validatePluginInput(input: unknown, path = \"PluginInput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.ir === undefined || obj.ir === null) {\n return `${path}.ir: required field is missing`;\n }\n {\n const err = validateIrSchema(obj.ir, `${path}.ir`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * PluginOutput PluginOutput represents the response payload returned by the `plugin` function.\n * \n * After processing the input schema, the plugin outputs this object containing\n * all files to be generated or errors to be displayed to the user.\n * \n * If there are no errors and at least one file is returned, VDL will write each\n * file to the specified path within the output directory. If there are errors,\n * VDL will display them to the user and not write any files.\n */\nexport type PluginOutput = {\n files?: PluginOutputFile[]\n errors?: PluginOutputError[]\n}\n\nexport function hydratePluginOutput(input: PluginOutput): PluginOutput {\n const hydratedFiles = input.files ? input.files.map(el => hydratePluginOutputFile(el)) : input.files\n const hydratedErrors = input.errors ? input.errors.map(el => hydratePluginOutputError(el)) : input.errors\n return {\n files: hydratedFiles,\n errors: hydratedErrors,\n }\n}\n\nexport function validatePluginOutput(input: unknown, path = \"PluginOutput\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.files !== undefined && obj.files !== null) {\n {\n if (!Array.isArray(obj.files)) {\n return `${path}.files: expected array, got ${typeof obj.files}`;\n }\n for (let i = 0; i < obj.files.length; i++) {\n {\n const err = validatePluginOutputFile(obj.files[i], `${path}.files[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n if (obj.errors !== undefined && obj.errors !== null) {\n {\n if (!Array.isArray(obj.errors)) {\n return `${path}.errors: expected array, got ${typeof obj.errors}`;\n }\n for (let i = 0; i < obj.errors.length; i++) {\n {\n const err = validatePluginOutputError(obj.errors[i], `${path}.errors[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n\n/**\n * PluginOutputError A structured error reported by the plugin.\n */\nexport type PluginOutputError = {\n message: string\n position?: Position\n}\n\nexport function hydratePluginOutputError(input: PluginOutputError): PluginOutputError {\n const hydratedMessage = input.message\n const hydratedPosition = input.position ? hydratePosition(input.position) : input.position\n return {\n message: hydratedMessage,\n position: hydratedPosition,\n }\n}\n\nexport function validatePluginOutputError(input: unknown, path = \"PluginOutputError\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position !== undefined && obj.position !== null) {\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n }\n return null;\n}\n\n/**\n * PluginOutputFile PluginOutputFile represents a single generated file produced by the plugin.\n * \n * This abstraction allows plugins to generate multiple files from a single\n * invocation, enabling patterns like one-file-per-type or splitting large\n * outputs across multiple modules.\n */\nexport type PluginOutputFile = {\n path: string\n content: string\n}\n\nexport function hydratePluginOutputFile(input: PluginOutputFile): PluginOutputFile {\n const hydratedPath = input.path\n const hydratedContent = input.content\n return {\n path: hydratedPath,\n content: hydratedContent,\n }\n}\n\nexport function validatePluginOutputFile(_input: unknown, _path = \"PluginOutputFile\"): string | null {\n return null;\n}\n\n/**\n * Position It represents a position within a file and is used for error\n * reporting, diagnostics, plugins, and tooling support.\n */\nexport type Position = {\n file: string\n line: number\n column: number\n}\n\nexport function hydratePosition(input: Position): Position {\n const hydratedFile = input.file\n const hydratedLine = input.line\n const hydratedColumn = input.column\n return {\n file: hydratedFile,\n line: hydratedLine,\n column: hydratedColumn,\n }\n}\n\nexport function validatePosition(_input: unknown, _path = \"Position\"): string | null {\n return null;\n}\n\n/**\n * TopLevelDoc Standalone documentation block.\n * \n * Used for top-level docstrings that are not attached to a type/enum/constant.\n */\nexport type TopLevelDoc = {\n position: Position\n content: string\n}\n\nexport function hydrateTopLevelDoc(input: TopLevelDoc): TopLevelDoc {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedContent = input.content\n return {\n position: hydratedPosition,\n content: hydratedContent,\n }\n}\n\nexport function validateTopLevelDoc(input: unknown, path = \"TopLevelDoc\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeDef Flattened type definition.\n * \n * All spreads are already expanded. The unified `typeRef` describes what this\n * type IS, a primitive, custom reference, map, array, or object with fields.\n */\nexport type TypeDef = {\n position: Position\n name: string\n doc?: string\n annotations: Annotation[]\n typeRef: TypeRef\n}\n\nexport function hydrateTypeDef(input: TypeDef): TypeDef {\n const hydratedPosition = hydratePosition(input.position)\n const hydratedName = input.name\n const hydratedDoc = input.doc ? input.doc : input.doc\n const hydratedAnnotations = input.annotations.map(el => hydrateAnnotation(el))\n const hydratedTypeRef = hydrateTypeRef(input.typeRef)\n return {\n position: hydratedPosition,\n name: hydratedName,\n doc: hydratedDoc,\n annotations: hydratedAnnotations,\n typeRef: hydratedTypeRef,\n }\n}\n\nexport function validateTypeDef(input: unknown, path = \"TypeDef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.position === undefined || obj.position === null) {\n return `${path}.position: required field is missing`;\n }\n {\n const err = validatePosition(obj.position, `${path}.position`);\n if (err !== null) return err;\n }\n if (obj.annotations === undefined || obj.annotations === null) {\n return `${path}.annotations: required field is missing`;\n }\n {\n if (!Array.isArray(obj.annotations)) {\n return `${path}.annotations: expected array, got ${typeof obj.annotations}`;\n }\n for (let i = 0; i < obj.annotations.length; i++) {\n {\n const err = validateAnnotation(obj.annotations[i], `${path}.annotations[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n if (obj.typeRef === undefined || obj.typeRef === null) {\n return `${path}.typeRef: required field is missing`;\n }\n {\n const err = validateTypeRef(obj.typeRef, `${path}.typeRef`);\n if (err !== null) return err;\n }\n return null;\n}\n\n/**\n * TypeRef Normalized type reference used by fields and constants.\n * \n * `kind` selects which payload fields are meaningful. Generators should inspect\n * `kind` first, then read the related payload fields.\n */\nexport type TypeRef = {\n kind: TypeKind\n primitiveName?: PrimitiveType\n typeName?: string\n enumName?: string\n enumType?: EnumValueType\n arrayType?: TypeRef\n arrayDims?: number\n mapType?: TypeRef\n objectFields?: Field[]\n}\n\nexport function hydrateTypeRef(input: TypeRef): TypeRef {\n const hydratedKind = input.kind\n const hydratedPrimitiveName = input.primitiveName ? input.primitiveName : input.primitiveName\n const hydratedTypeName = input.typeName ? input.typeName : input.typeName\n const hydratedEnumName = input.enumName ? input.enumName : input.enumName\n const hydratedEnumType = input.enumType ? input.enumType : input.enumType\n const hydratedArrayType = input.arrayType ? hydrateTypeRef(input.arrayType) : input.arrayType\n const hydratedArrayDims = input.arrayDims ? input.arrayDims : input.arrayDims\n const hydratedMapType = input.mapType ? hydrateTypeRef(input.mapType) : input.mapType\n const hydratedObjectFields = input.objectFields ? input.objectFields.map(el => hydrateField(el)) : input.objectFields\n return {\n kind: hydratedKind,\n primitiveName: hydratedPrimitiveName,\n typeName: hydratedTypeName,\n enumName: hydratedEnumName,\n enumType: hydratedEnumType,\n arrayType: hydratedArrayType,\n arrayDims: hydratedArrayDims,\n mapType: hydratedMapType,\n objectFields: hydratedObjectFields,\n }\n}\n\nexport function validateTypeRef(input: unknown, path = \"TypeRef\"): string | null {\n if (input === null || input === undefined || typeof input !== \"object\") {\n return `${path}: expected object, got ${typeof input}`;\n }\n const obj = input as Record<string, unknown>;\n\n if (obj.kind === undefined || obj.kind === null) {\n return `${path}.kind: required field is missing`;\n }\n {\n if (!isTypeKind(obj.kind)) {\n return `${path}.kind: invalid enum value '${obj.kind}' for TypeKind`;\n }\n }\n if (obj.primitiveName !== undefined && obj.primitiveName !== null) {\n {\n if (!isPrimitiveType(obj.primitiveName)) {\n return `${path}.primitiveName: invalid enum value '${obj.primitiveName}' for PrimitiveType`;\n }\n }\n }\n if (obj.enumType !== undefined && obj.enumType !== null) {\n {\n if (!isEnumValueType(obj.enumType)) {\n return `${path}.enumType: invalid enum value '${obj.enumType}' for EnumValueType`;\n }\n }\n }\n if (obj.arrayType !== undefined && obj.arrayType !== null) {\n {\n const err = validateTypeRef(obj.arrayType, `${path}.arrayType`);\n if (err !== null) return err;\n }\n }\n if (obj.mapType !== undefined && obj.mapType !== null) {\n {\n const err = validateTypeRef(obj.mapType, `${path}.mapType`);\n if (err !== null) return err;\n }\n }\n if (obj.objectFields !== undefined && obj.objectFields !== null) {\n {\n if (!Array.isArray(obj.objectFields)) {\n return `${path}.objectFields: expected array, got ${typeof obj.objectFields}`;\n }\n for (let i = 0; i < obj.objectFields.length; i++) {\n {\n const err = validateField(obj.objectFields[i], `${path}.objectFields[${i}]`);\n if (err !== null) return err;\n }\n }\n }\n }\n return null;\n}\n","import type { Annotation, LiteralValue } from \"../types\";\n\n/**\n * Returns the first annotation that matches the provided name.\n */\nexport function getAnnotation(\n annotations: Annotation[] | undefined,\n name: string,\n): Annotation | undefined {\n if (!annotations) return undefined;\n return annotations.find((anno) => anno.name === name);\n}\n\n/**\n * Returns the raw literal argument stored in an annotation.\n *\n * VDL annotations currently expose a single literal argument.\n * Pair this helper with `unwrapLiteral` when you need a plain JavaScript value.\n */\nexport function getAnnotationArgs(\n annotations: Annotation[] | undefined,\n name: string,\n): LiteralValue | undefined {\n const anno = getAnnotation(annotations, name);\n return anno?.argument;\n}\n","import type { LiteralValue } from \"../types\";\n\n/**\n * Native JavaScript value produced by `unwrapLiteral`.\n *\n * `undefined` is preserved when a literal is missing its kind-specific payload.\n * `null` is returned for unknown literal kinds to keep the resolver non-throwing.\n */\nexport type UnwrappedLiteral =\n | string\n | number\n | boolean\n | null\n | undefined\n | UnwrappedLiteral[]\n | { [key: string]: UnwrappedLiteral };\n\n/**\n * Resolves a `LiteralValue` into its native JavaScript representation.\n *\n * Pass a generic when you already know the expected shape.\n * Omit it to get `unknown` and narrow the result yourself.\n *\n * The generic only affects TypeScript types. It does not validate the runtime value.\n */\nexport function unwrapLiteral<T = unknown>(value: LiteralValue): T {\n return unwrapLiteralValue(value) as T;\n}\n\n/**\n * Performs the recursive literal resolution used by `unwrapLiteral`.\n */\nfunction unwrapLiteralValue(value: LiteralValue): UnwrappedLiteral {\n switch (value.kind) {\n case \"string\":\n return value.stringValue;\n case \"int\":\n return value.intValue;\n case \"float\":\n return value.floatValue;\n case \"bool\":\n return value.boolValue;\n case \"object\": {\n const resolvedObject: { [key: string]: UnwrappedLiteral } = {};\n const entries = value.objectEntries ?? [];\n\n for (const entry of entries) {\n resolvedObject[entry.key] = unwrapLiteralValue(entry.value);\n }\n\n return resolvedObject;\n }\n case \"array\": {\n const items = value.arrayItems ?? [];\n return items.map((item) => unwrapLiteralValue(item));\n }\n default:\n return null;\n }\n}\n","/**\n * Returns a string option or the provided fallback when the key is missing.\n */\nexport function getOptionString(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: string,\n): string {\n const value = options?.[key];\n return value === undefined ? defaultValue : value;\n}\n\n/**\n * Returns a boolean option using common truthy and falsy string values.\n *\n * Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.\n *\n * Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.\n *\n * Invalid values fall back to the provided default.\n */\nexport function getOptionBool(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: boolean,\n): boolean {\n const value = options?.[key];\n\n if (value === undefined) {\n return defaultValue;\n }\n\n switch (value.trim().toLowerCase()) {\n case \"true\":\n case \"1\":\n case \"yes\":\n case \"on\":\n case \"enable\":\n case \"enabled\":\n case \"y\":\n return true;\n case \"false\":\n case \"0\":\n case \"no\":\n case \"off\":\n case \"disable\":\n case \"disabled\":\n case \"n\":\n return false;\n default:\n return defaultValue;\n }\n}\n\n/**\n * Returns a numeric option or the provided fallback when parsing fails.\n *\n * Empty, invalid, and non-finite values fall back to the default.\n */\nexport function getOptionNumber(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: number,\n): number {\n const value = options?.[key];\n\n if (value === undefined) {\n return defaultValue;\n }\n\n const trimmedValue = value.trim();\n\n if (trimmedValue === \"\") {\n return defaultValue;\n }\n\n const parsedValue = Number(trimmedValue);\n return Number.isFinite(parsedValue) ? parsedValue : defaultValue;\n}\n\n/**\n * Returns a string array option from a separator-delimited value.\n *\n * Empty items are removed and each entry is trimmed.\n *\n * Missing values return the provided default.\n *\n * @example\n * // For options: { \"features\": \"feature1, feature2, feature3\" }\n * getOptionArray(options, \"features\", [], \",\")\n * // returns [\"feature1\", \"feature2\", \"feature3\"]\n */\nexport function getOptionArray(\n options: Record<string, string> | undefined,\n key: string,\n defaultValue: string[] = [],\n separator = \",\",\n): string[] {\n const value = options?.[key];\n\n if (value === undefined) {\n return defaultValue;\n }\n\n const trimmedValue = value.trim();\n\n if (trimmedValue === \"\") {\n return [];\n }\n\n return trimmedValue\n .split(separator)\n .map((item) => item.trim())\n .filter((item) => item.length > 0);\n}\n"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
getOptionArray,
|
|
5
|
+
getOptionBool,
|
|
6
|
+
getOptionNumber,
|
|
7
|
+
getOptionString,
|
|
8
|
+
} from "./options";
|
|
9
|
+
|
|
10
|
+
describe("getOptionString", () => {
|
|
11
|
+
it("returns the stored string value", () => {
|
|
12
|
+
expect(getOptionString({ prefix: "Api" }, "prefix", "Model")).toBe("Api");
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
it("returns the fallback when the key is missing", () => {
|
|
16
|
+
expect(getOptionString(undefined, "prefix", "Model")).toBe("Model");
|
|
17
|
+
expect(getOptionString({}, "prefix", "Model")).toBe("Model");
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
describe("getOptionBool", () => {
|
|
22
|
+
it("parses common truthy values", () => {
|
|
23
|
+
expect(getOptionBool({ enabled: "true" }, "enabled", false)).toBe(true);
|
|
24
|
+
expect(getOptionBool({ enabled: " YES " }, "enabled", false)).toBe(true);
|
|
25
|
+
expect(getOptionBool({ enabled: "1" }, "enabled", false)).toBe(true);
|
|
26
|
+
expect(getOptionBool({ enabled: "on" }, "enabled", false)).toBe(true);
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
it("parses common falsy values", () => {
|
|
30
|
+
expect(getOptionBool({ enabled: "false" }, "enabled", true)).toBe(false);
|
|
31
|
+
expect(getOptionBool({ enabled: " no " }, "enabled", true)).toBe(false);
|
|
32
|
+
expect(getOptionBool({ enabled: "0" }, "enabled", true)).toBe(false);
|
|
33
|
+
expect(getOptionBool({ enabled: "off" }, "enabled", true)).toBe(false);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it("returns the fallback for missing or invalid values", () => {
|
|
37
|
+
expect(getOptionBool(undefined, "enabled", true)).toBe(true);
|
|
38
|
+
expect(getOptionBool({}, "enabled", false)).toBe(false);
|
|
39
|
+
expect(getOptionBool({ enabled: "maybe" }, "enabled", true)).toBe(true);
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
describe("getOptionNumber", () => {
|
|
44
|
+
it("parses numeric values", () => {
|
|
45
|
+
expect(getOptionNumber({ version: "2" }, "version", 1)).toBe(2);
|
|
46
|
+
expect(getOptionNumber({ version: " 3.5 " }, "version", 1)).toBe(3.5);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
it("returns the fallback for missing, empty, or invalid values", () => {
|
|
50
|
+
expect(getOptionNumber(undefined, "version", 1)).toBe(1);
|
|
51
|
+
expect(getOptionNumber({}, "version", 1)).toBe(1);
|
|
52
|
+
expect(getOptionNumber({ version: " " }, "version", 1)).toBe(1);
|
|
53
|
+
expect(getOptionNumber({ version: "hello" }, "version", 1)).toBe(1);
|
|
54
|
+
expect(getOptionNumber({ version: "Infinity" }, "version", 1)).toBe(1);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
describe("getOptionArray", () => {
|
|
59
|
+
it("splits and trims comma-separated values", () => {
|
|
60
|
+
expect(getOptionArray({ tags: "api, core , v1" }, "tags")).toEqual([
|
|
61
|
+
"api",
|
|
62
|
+
"core",
|
|
63
|
+
"v1",
|
|
64
|
+
]);
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
it("supports custom separators", () => {
|
|
68
|
+
expect(getOptionArray({ tags: "api|core|v1" }, "tags", [], "|")).toEqual([
|
|
69
|
+
"api",
|
|
70
|
+
"core",
|
|
71
|
+
"v1",
|
|
72
|
+
]);
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
it("returns the fallback for missing values", () => {
|
|
76
|
+
expect(getOptionArray(undefined, "tags", ["default"])).toEqual(["default"]);
|
|
77
|
+
expect(getOptionArray({}, "tags", ["default"])).toEqual(["default"]);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it("returns an empty array for blank values and removes empty items", () => {
|
|
81
|
+
expect(getOptionArray({ tags: " " }, "tags", ["default"])).toEqual([]);
|
|
82
|
+
expect(getOptionArray({ tags: "api,, core, ,v1" }, "tags")).toEqual([
|
|
83
|
+
"api",
|
|
84
|
+
"core",
|
|
85
|
+
"v1",
|
|
86
|
+
]);
|
|
87
|
+
});
|
|
88
|
+
});
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns a string option or the provided fallback when the key is missing.
|
|
3
|
+
*/
|
|
4
|
+
export function getOptionString(
|
|
5
|
+
options: Record<string, string> | undefined,
|
|
6
|
+
key: string,
|
|
7
|
+
defaultValue: string,
|
|
8
|
+
): string {
|
|
9
|
+
const value = options?.[key];
|
|
10
|
+
return value === undefined ? defaultValue : value;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Returns a boolean option using common truthy and falsy string values.
|
|
15
|
+
*
|
|
16
|
+
* Accepted truthy values: `true`, `1`, `yes`, `on`, `enable`, `enabled`, `y`.
|
|
17
|
+
*
|
|
18
|
+
* Accepted falsy values: `false`, `0`, `no`, `off`, `disable`, `disabled`, `n`.
|
|
19
|
+
*
|
|
20
|
+
* Invalid values fall back to the provided default.
|
|
21
|
+
*/
|
|
22
|
+
export function getOptionBool(
|
|
23
|
+
options: Record<string, string> | undefined,
|
|
24
|
+
key: string,
|
|
25
|
+
defaultValue: boolean,
|
|
26
|
+
): boolean {
|
|
27
|
+
const value = options?.[key];
|
|
28
|
+
|
|
29
|
+
if (value === undefined) {
|
|
30
|
+
return defaultValue;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
switch (value.trim().toLowerCase()) {
|
|
34
|
+
case "true":
|
|
35
|
+
case "1":
|
|
36
|
+
case "yes":
|
|
37
|
+
case "on":
|
|
38
|
+
case "enable":
|
|
39
|
+
case "enabled":
|
|
40
|
+
case "y":
|
|
41
|
+
return true;
|
|
42
|
+
case "false":
|
|
43
|
+
case "0":
|
|
44
|
+
case "no":
|
|
45
|
+
case "off":
|
|
46
|
+
case "disable":
|
|
47
|
+
case "disabled":
|
|
48
|
+
case "n":
|
|
49
|
+
return false;
|
|
50
|
+
default:
|
|
51
|
+
return defaultValue;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Returns a numeric option or the provided fallback when parsing fails.
|
|
57
|
+
*
|
|
58
|
+
* Empty, invalid, and non-finite values fall back to the default.
|
|
59
|
+
*/
|
|
60
|
+
export function getOptionNumber(
|
|
61
|
+
options: Record<string, string> | undefined,
|
|
62
|
+
key: string,
|
|
63
|
+
defaultValue: number,
|
|
64
|
+
): number {
|
|
65
|
+
const value = options?.[key];
|
|
66
|
+
|
|
67
|
+
if (value === undefined) {
|
|
68
|
+
return defaultValue;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const trimmedValue = value.trim();
|
|
72
|
+
|
|
73
|
+
if (trimmedValue === "") {
|
|
74
|
+
return defaultValue;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
const parsedValue = Number(trimmedValue);
|
|
78
|
+
return Number.isFinite(parsedValue) ? parsedValue : defaultValue;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Returns a string array option from a separator-delimited value.
|
|
83
|
+
*
|
|
84
|
+
* Empty items are removed and each entry is trimmed.
|
|
85
|
+
*
|
|
86
|
+
* Missing values return the provided default.
|
|
87
|
+
*
|
|
88
|
+
* @example
|
|
89
|
+
* // For options: { "features": "feature1, feature2, feature3" }
|
|
90
|
+
* getOptionArray(options, "features", [], ",")
|
|
91
|
+
* // returns ["feature1", "feature2", "feature3"]
|
|
92
|
+
*/
|
|
93
|
+
export function getOptionArray(
|
|
94
|
+
options: Record<string, string> | undefined,
|
|
95
|
+
key: string,
|
|
96
|
+
defaultValue: string[] = [],
|
|
97
|
+
separator = ",",
|
|
98
|
+
): string[] {
|
|
99
|
+
const value = options?.[key];
|
|
100
|
+
|
|
101
|
+
if (value === undefined) {
|
|
102
|
+
return defaultValue;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
const trimmedValue = value.trim();
|
|
106
|
+
|
|
107
|
+
if (trimmedValue === "") {
|
|
108
|
+
return [];
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return trimmedValue
|
|
112
|
+
.split(separator)
|
|
113
|
+
.map((item) => item.trim())
|
|
114
|
+
.filter((item) => item.length > 0);
|
|
115
|
+
}
|