politty 0.3.1 → 0.3.3

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.
Files changed (63) hide show
  1. package/README.md +84 -2
  2. package/dist/{arg-registry-w5mMKJkZ.d.ts → arg-registry-B4a4Fj7f.d.cts} +51 -2
  3. package/dist/arg-registry-B4a4Fj7f.d.cts.map +1 -0
  4. package/dist/{arg-registry-i6SA4l-E.d.cts → arg-registry-C3GP-5C9.d.ts} +51 -2
  5. package/dist/arg-registry-C3GP-5C9.d.ts.map +1 -0
  6. package/dist/augment.d.cts +1 -1
  7. package/dist/augment.d.ts +1 -1
  8. package/dist/completion/index.cjs +24 -461
  9. package/dist/completion/index.cjs.map +1 -1
  10. package/dist/completion/index.d.cts +13 -91
  11. package/dist/completion/index.d.cts.map +1 -1
  12. package/dist/completion/index.d.ts +13 -91
  13. package/dist/completion/index.d.ts.map +1 -1
  14. package/dist/completion/index.js +12 -455
  15. package/dist/completion/index.js.map +1 -1
  16. package/dist/docs/index.cjs +5 -47
  17. package/dist/docs/index.cjs.map +1 -1
  18. package/dist/docs/index.d.cts +2 -1
  19. package/dist/docs/index.d.cts.map +1 -1
  20. package/dist/docs/index.d.ts +2 -1
  21. package/dist/docs/index.d.ts.map +1 -1
  22. package/dist/docs/index.js +2 -2
  23. package/dist/extractor-CCi4rjSI.d.ts +238 -0
  24. package/dist/extractor-CCi4rjSI.d.ts.map +1 -0
  25. package/dist/extractor-CqfDnGKd.cjs +970 -0
  26. package/dist/extractor-CqfDnGKd.cjs.map +1 -0
  27. package/dist/extractor-DsJ6hYqQ.d.cts +238 -0
  28. package/dist/extractor-DsJ6hYqQ.d.cts.map +1 -0
  29. package/dist/extractor-JfoYSoMk.js +898 -0
  30. package/dist/extractor-JfoYSoMk.js.map +1 -0
  31. package/dist/index.cjs +8 -5
  32. package/dist/index.d.cts +5 -3
  33. package/dist/index.d.cts.map +1 -1
  34. package/dist/index.d.ts +5 -3
  35. package/dist/index.d.ts.map +1 -1
  36. package/dist/index.js +5 -4
  37. package/dist/{runner-B38UBqhv.cjs → runner-9dLE13Dv.cjs} +42 -25
  38. package/dist/runner-9dLE13Dv.cjs.map +1 -0
  39. package/dist/{runner-CUN50BqK.js → runner-LJRI4haB.js} +39 -22
  40. package/dist/runner-LJRI4haB.js.map +1 -0
  41. package/dist/{schema-extractor-CXeUTW_Z.d.cts → schema-extractor-CHiBRT39.d.ts} +6 -1
  42. package/dist/schema-extractor-CHiBRT39.d.ts.map +1 -0
  43. package/dist/{schema-extractor-1YXqFSDT.js → schema-extractor-CP3ar0Wi.js} +43 -4
  44. package/dist/schema-extractor-CP3ar0Wi.js.map +1 -0
  45. package/dist/{schema-extractor-B9D3Rf22.cjs → schema-extractor-Cv7ipqLS.cjs} +44 -5
  46. package/dist/schema-extractor-Cv7ipqLS.cjs.map +1 -0
  47. package/dist/{schema-extractor-Cl_D04BX.d.ts → schema-extractor-DyfK21m_.d.cts} +6 -1
  48. package/dist/schema-extractor-DyfK21m_.d.cts.map +1 -0
  49. package/dist/{subcommand-router-Vf-0w9P4.cjs → subcommand-router-4d1Xbp8B.cjs} +53 -1
  50. package/dist/{subcommand-router-Vf-0w9P4.cjs.map → subcommand-router-4d1Xbp8B.cjs.map} +1 -1
  51. package/package.json +9 -6
  52. package/dist/arg-registry-i6SA4l-E.d.cts.map +0 -1
  53. package/dist/arg-registry-w5mMKJkZ.d.ts.map +0 -1
  54. package/dist/command-Bgd-yIwv.cjs +0 -25
  55. package/dist/command-Bgd-yIwv.cjs.map +0 -1
  56. package/dist/command-D-P2Pc3J.js +0 -20
  57. package/dist/command-D-P2Pc3J.js.map +0 -1
  58. package/dist/runner-B38UBqhv.cjs.map +0 -1
  59. package/dist/runner-CUN50BqK.js.map +0 -1
  60. package/dist/schema-extractor-1YXqFSDT.js.map +0 -1
  61. package/dist/schema-extractor-B9D3Rf22.cjs.map +0 -1
  62. package/dist/schema-extractor-CXeUTW_Z.d.cts.map +0 -1
  63. package/dist/schema-extractor-Cl_D04BX.d.ts.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"schema-extractor-1YXqFSDT.js","names":["getArgMeta","getArgMetaFromRegistry"],"sources":["../src/core/arg-registry.ts","../src/core/schema-extractor.ts"],"sourcesContent":["import { z } from \"zod\";\n\n/**\n * Base metadata shared by all argument types\n */\nexport interface BaseArgMeta {\n /** Argument description */\n description?: string;\n /** Treat as positional argument */\n positional?: boolean;\n /** Placeholder for help display */\n placeholder?: string;\n /**\n * Environment variable name(s) to read value from.\n * If an array is provided, earlier entries take priority.\n * CLI arguments always take precedence over environment variables.\n *\n * @example\n * ```ts\n * // Single env var\n * port: arg(z.coerce.number(), { env: \"PORT\" })\n *\n * // Multiple env vars (PORT takes priority over SERVER_PORT)\n * port: arg(z.coerce.number(), { env: [\"PORT\", \"SERVER_PORT\"] })\n * ```\n */\n env?: string | string[];\n}\n\n/**\n * Metadata for regular arguments (non-builtin aliases)\n */\nexport interface RegularArgMeta extends BaseArgMeta {\n /** Short alias (e.g., 'v' for --verbose) */\n alias?: string;\n}\n\n/**\n * Metadata for overriding built-in aliases (-h, -H)\n */\nexport interface BuiltinOverrideArgMeta extends BaseArgMeta {\n /** Built-in alias to override ('h' or 'H') */\n alias: \"h\" | \"H\";\n /** Must be true to override built-in aliases */\n overrideBuiltinAlias: true;\n}\n\n/**\n * Metadata options for argument definition\n */\nexport type ArgMeta = RegularArgMeta | BuiltinOverrideArgMeta;\n\n/**\n * Custom registry for politty argument metadata\n * This avoids polluting Zod's GlobalMeta\n */\nexport const argRegistry = z.registry<ArgMeta>();\n\n/**\n * Register metadata for a Zod schema\n *\n * @param schema - The Zod schema\n * @param meta - Argument metadata\n * @returns The same schema (for chaining)\n *\n * @example\n * ```ts\n * import { z } from \"zod\";\n * import { arg, defineCommand } from \"politty\";\n *\n * const cmd = defineCommand({\n * args: z.object({\n * name: arg(z.string(), { description: \"User name\", positional: true }),\n * verbose: arg(z.boolean().default(false), { alias: \"v\" }),\n * }),\n * run: (args) => {\n * console.log(args.name, args.verbose);\n * },\n * });\n * ```\n */\n/**\n * Type helper to validate ArgMeta\n * Forces a type error if alias is \"h\" or \"H\" without overrideBuiltinAlias: true\n */\ntype ValidateArgMeta<M> = M extends { alias: \"h\" | \"H\" }\n ? M extends { overrideBuiltinAlias: true }\n ? M\n : {\n [K in keyof M]: M[K];\n } & {\n __typeError: \"Alias 'h' or 'H' requires overrideBuiltinAlias: true\";\n }\n : M;\n\nexport function arg<T extends z.ZodType>(schema: T): T;\nexport function arg<T extends z.ZodType, M extends ArgMeta>(schema: T, meta: ValidateArgMeta<M>): T;\nexport function arg<T extends z.ZodType, M extends ArgMeta>(\n schema: T,\n meta?: ValidateArgMeta<M>,\n): T {\n if (meta) {\n argRegistry.add(schema, meta as ArgMeta);\n }\n return schema;\n}\n\n/**\n * Get metadata for a schema from the registry\n *\n * @param schema - The Zod schema\n * @returns The metadata if registered, undefined otherwise\n */\nexport function getArgMeta(schema: z.ZodType): ArgMeta | undefined {\n return argRegistry.get(schema);\n}\n","import { z } from \"zod\";\nimport type { AnyCommand, ArgsSchema } from \"../types.js\";\nimport { getArgMeta as getArgMetaFromRegistry, type ArgMeta } from \"./arg-registry.js\";\n\n/**\n * Get ArgMeta from both the custom registry and Zod's _def\n * Priority: custom registry > _def.argMeta\n */\nfunction getArgMeta(schema: z.ZodType): ArgMeta | undefined {\n // First check custom registry\n const fromRegistry = getArgMetaFromRegistry(schema);\n if (fromRegistry) return fromRegistry;\n // Check Zod native meta\n // Some Zod versions or extensions use a global registry accessed via .meta()\n if (typeof (schema as any).meta === \"function\") {\n const meta = (schema as any).meta();\n if (meta && typeof meta === \"object\") {\n return meta as ArgMeta;\n }\n }\n\n // Then check _def.argMeta (for augmented Zod types)\n const def = (schema as any)._def;\n if (def?.argMeta) return def.argMeta;\n\n // Also check _def.meta just in case\n if (def?.meta) return def.meta as ArgMeta;\n\n return undefined;\n}\n\n/**\n * Resolved metadata for an argument field\n */\nexport interface ResolvedFieldMeta {\n /** Field name (camelCase, as defined in schema) */\n name: string;\n /** CLI option name (kebab-case, for command line usage) */\n cliName: string;\n /** Short alias (e.g., 'v' for --verbose) */\n alias?: string | undefined;\n /** Argument description */\n description?: string | undefined;\n /** Whether this is a positional argument */\n positional: boolean;\n /** Placeholder for help display */\n placeholder?: string | undefined;\n /**\n * Environment variable name(s) to read value from.\n * If an array, earlier entries take priority.\n */\n env?: string | string[] | undefined;\n /** Whether this argument is required */\n required: boolean;\n /** Default value if any */\n defaultValue?: unknown;\n /** Detected type from schema */\n type: \"string\" | \"number\" | \"boolean\" | \"array\" | \"unknown\";\n /** Original Zod schema */\n schema: z.ZodType;\n /** True if this overrides built-in aliases (-h, -H) */\n overrideBuiltinAlias?: true;\n}\n\n/**\n * Extracted fields from a schema\n */\nexport interface ExtractedFields {\n /** All field definitions */\n fields: ResolvedFieldMeta[];\n /** Original schema for validation */\n schema: ArgsSchema;\n /** Schema type */\n schemaType: \"object\" | \"discriminatedUnion\" | \"union\" | \"xor\" | \"intersection\";\n /** Discriminator key (for discriminatedUnion) */\n discriminator?: string;\n /** Variants (for discriminatedUnion) */\n variants?: Array<{\n discriminatorValue: string;\n fields: ResolvedFieldMeta[];\n description?: string;\n }>;\n /** Options (for union) */\n unionOptions?: ExtractedFields[];\n /** Schema description */\n description?: string;\n /**\n * Unknown keys handling mode\n * - \"strict\": Unknown keys cause validation errors (z.strictObject or z.object().strict())\n * - \"strip\": Unknown keys trigger warnings (default, z.object())\n * - \"passthrough\": Unknown keys are silently ignored (z.looseObject or z.object().passthrough())\n */\n unknownKeysMode: UnknownKeysMode;\n}\n\n/**\n * Unknown keys handling mode for object schemas\n * - \"strict\": Unknown keys cause validation errors\n * - \"strip\": Unknown keys are silently ignored (default)\n * - \"passthrough\": Unknown keys are passed through\n */\nexport type UnknownKeysMode = \"strict\" | \"strip\" | \"passthrough\";\n\n// Internal type for accessing zod v4 internals\ninterface ZodV4Def {\n type?: string;\n innerType?: z.ZodType;\n schema?: z.ZodType;\n defaultValue?: unknown;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n shape?: Record<string, any>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n options?: any[];\n discriminator?: string;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n left?: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n right?: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n catchall?: any;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype ZodSchemaWithDef = z.ZodType & { def?: ZodV4Def; _def?: ZodV4Def; type?: string; shape?: any };\n\n/**\n * Get the type name from a zod schema (v4 compatible)\n */\nfunction getTypeName(schema: z.ZodType): string | undefined {\n const s = schema as ZodSchemaWithDef;\n return s.def?.type ?? s._def?.type ?? s.type;\n}\n\n/**\n * Detect unknown keys handling mode from a Zod object schema\n *\n * In Zod v4:\n * - Default (strip): _def.catchall is undefined\n * - strict: _def.catchall is ZodNever (type = \"never\")\n * - passthrough: _def.catchall is ZodUnknown (type = \"unknown\")\n */\nexport function getUnknownKeysMode(schema: z.ZodType): UnknownKeysMode {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const catchall = def?.catchall;\n\n if (!catchall) {\n // Default behavior: strip unknown keys (but we want to warn)\n return \"strip\";\n }\n\n const catchallType = getTypeName(catchall);\n\n if (catchallType === \"never\") {\n // z.strictObject() or z.object().strict() - reject unknown keys\n return \"strict\";\n }\n\n if (catchallType === \"unknown\" || catchallType === \"any\") {\n // z.looseObject() or z.object().passthrough() - allow unknown keys\n return \"passthrough\";\n }\n\n // Unknown catchall type, default to strip behavior\n return \"strip\";\n}\n\n/**\n * Get the inner schema, unwrapping optional, nullable, default, etc.\n */\nfunction unwrapSchema(schema: z.ZodType): z.ZodType {\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n if (typeName === \"optional\" || typeName === \"nullable\" || typeName === \"default\") {\n const innerSchema = def?.innerType;\n if (innerSchema) {\n return unwrapSchema(innerSchema);\n }\n }\n\n // Handle effects (transform, refine, etc.)\n if (typeName === \"pipe\") {\n const innerSchema = def?.schema;\n if (innerSchema) {\n return unwrapSchema(innerSchema);\n }\n }\n\n return schema;\n}\n\n/**\n * Detect the base type of a schema\n */\nfunction detectType(schema: z.ZodType): \"string\" | \"number\" | \"boolean\" | \"array\" | \"unknown\" {\n const innerSchema = unwrapSchema(schema);\n const typeName = getTypeName(innerSchema);\n\n switch (typeName) {\n case \"string\":\n return \"string\";\n case \"number\":\n case \"int\":\n return \"number\";\n case \"boolean\":\n return \"boolean\";\n case \"array\":\n return \"array\";\n default:\n return \"unknown\";\n }\n}\n\n/**\n * Convert camelCase to kebab-case\n * @example toKebabCase(\"dryRun\") => \"dry-run\"\n * @example toKebabCase(\"outputDir\") => \"output-dir\"\n * @example toKebabCase(\"XMLParser\") => \"xml-parser\"\n */\nexport function toKebabCase(str: string): string {\n return str\n .replace(/([a-z])([A-Z])/g, \"$1-$2\")\n .replace(/([A-Z]+)([A-Z][a-z])/g, \"$1-$2\")\n .toLowerCase();\n}\n\n/**\n * Check if a schema is required (not optional or has default)\n *\n * Note: We only check isOptional(), not isNullable(), because CLI arguments\n * are either present (string value) or absent (undefined), never null.\n * Also, some coerce types incorrectly report isNullable()=true.\n */\nfunction isRequired(schema: z.ZodType): boolean {\n return !schema.isOptional();\n}\n\n/**\n * Extract default value from schema if present\n */\nfunction extractDefaultValue(schema: z.ZodType): unknown {\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n if (typeName === \"default\") {\n const defaultValue = def?.defaultValue;\n // In zod v4, defaultValue can be a direct value or a function\n if (typeof defaultValue === \"function\") {\n return defaultValue();\n }\n return defaultValue;\n }\n\n // Check for nested default in optional/nullable\n if (typeName === \"optional\" || typeName === \"nullable\") {\n const innerSchema = def?.innerType;\n if (innerSchema) {\n return extractDefaultValue(innerSchema);\n }\n }\n\n return undefined;\n}\n\n/**\n * Extract description from schema\n */\nfunction extractDescription(schema: z.ZodType): string | undefined {\n // Check direct description\n if (schema.description) {\n return schema.description;\n }\n\n // Check inner schema for wrapped types\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n if (typeName === \"optional\" || typeName === \"nullable\" || typeName === \"default\") {\n const innerSchema = def?.innerType;\n if (innerSchema) {\n return extractDescription(innerSchema);\n }\n }\n\n return undefined;\n}\n\n/**\n * Resolve field metadata from schema and argRegistry\n */\nfunction resolveFieldMeta(name: string, schema: z.ZodType): ResolvedFieldMeta {\n // Get metadata from argRegistry\n const argMeta = getArgMeta(schema) ?? getArgMeta(unwrapSchema(schema));\n\n // Priority: argRegistry > schema.describe()\n const description = argMeta?.description ?? extractDescription(schema);\n\n // Convert camelCase field name to kebab-case for CLI usage\n const cliName = toKebabCase(name);\n\n const meta: ResolvedFieldMeta = {\n name,\n cliName,\n alias: argMeta?.alias,\n description,\n positional: argMeta?.positional ?? false,\n placeholder: argMeta?.placeholder,\n env: argMeta?.env,\n required: isRequired(schema),\n defaultValue: extractDefaultValue(schema),\n type: detectType(schema),\n schema,\n };\n\n // Add overrideBuiltinAlias only if it's true\n if (argMeta && \"overrideBuiltinAlias\" in argMeta && argMeta.overrideBuiltinAlias === true) {\n meta.overrideBuiltinAlias = true;\n }\n\n return meta;\n}\n\n/**\n * Get shape from a ZodObject\n */\nfunction getObjectShape(schema: z.ZodType): Record<string, z.ZodType> {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n return def?.shape ?? s.shape ?? {};\n}\n\n/**\n * Extract fields from a ZodObject\n */\nfunction extractFromObject(schema: z.ZodType): ResolvedFieldMeta[] {\n const shape = getObjectShape(schema);\n return Object.entries(shape).map(([name, fieldSchema]) => resolveFieldMeta(name, fieldSchema));\n}\n\n/**\n * Extract fields from a discriminated union\n */\nfunction extractFromDiscriminatedUnion(schema: z.ZodType): ExtractedFields {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const discriminator = def?.discriminator ?? \"\";\n const options = def?.options ?? [];\n\n // Collect all unique fields across all variants\n const allFieldsMap = new Map<string, ResolvedFieldMeta>();\n const variants: ExtractedFields[\"variants\"] = [];\n\n for (const option of options) {\n const shape = getObjectShape(option as z.ZodObject<z.ZodRawShape>);\n const variantFields: ResolvedFieldMeta[] = [];\n\n // Get discriminator value\n let discriminatorValue = \"\";\n const discriminatorSchema = shape[discriminator];\n if (discriminatorSchema) {\n const typeName = getTypeName(discriminatorSchema);\n if (typeName === \"literal\") {\n const litDef =\n (discriminatorSchema as ZodSchemaWithDef).def ??\n (discriminatorSchema as ZodSchemaWithDef)._def;\n // In Zod v4, literal values are in _def.values array\n const value = (litDef as { value?: unknown; values?: unknown[] })?.value;\n const values = (litDef as { value?: unknown; values?: unknown[] })?.values;\n discriminatorValue = String(value ?? values?.[0] ?? \"\");\n }\n }\n\n for (const [name, fieldSchema] of Object.entries(shape)) {\n const fieldMeta = resolveFieldMeta(name, fieldSchema);\n variantFields.push(fieldMeta);\n\n // Add to all fields map (first occurrence wins for metadata)\n if (!allFieldsMap.has(name)) {\n allFieldsMap.set(name, fieldMeta);\n }\n }\n\n // Extract description from the variant option\n const variantDescription = extractDescription(option as z.ZodType);\n\n variants.push({\n discriminatorValue,\n fields: variantFields,\n ...(variantDescription ? { description: variantDescription } : {}),\n });\n }\n\n const description = extractDescription(schema);\n return {\n fields: Array.from(allFieldsMap.values()),\n schema: schema as ArgsSchema,\n schemaType: \"discriminatedUnion\",\n unknownKeysMode: getUnknownKeysMode(schema),\n discriminator,\n variants,\n ...(description ? { description } : {}),\n };\n}\n\n/**\n * Extract fields from a union-like schema (union or xor)\n */\nfunction extractFromUnionLike(schema: z.ZodType, schemaType: \"union\" | \"xor\"): ExtractedFields {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const options = def?.options ?? [];\n\n // Collect all unique fields across all options\n const allFieldsMap = new Map<string, ResolvedFieldMeta>();\n const unionOptions: ExtractedFields[] = [];\n\n for (const option of options) {\n // Extract fields for this option recursively\n // We cast to ArgsSchema because we expect options to be objects or other supported types\n const extracted = extractFields(option as ArgsSchema);\n unionOptions.push(extracted);\n\n // Add to combined fields map\n for (const field of extracted.fields) {\n if (!allFieldsMap.has(field.name)) {\n allFieldsMap.set(field.name, field);\n }\n }\n }\n\n const description = extractDescription(schema);\n return {\n fields: Array.from(allFieldsMap.values()),\n schema: schema as ArgsSchema,\n schemaType,\n unknownKeysMode: getUnknownKeysMode(schema),\n unionOptions,\n ...(description ? { description } : {}),\n };\n}\n\n/**\n * Extract fields from an intersection\n */\nfunction extractFromIntersection(schema: z.ZodType): ExtractedFields {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const left = def?.left;\n const right = def?.right;\n\n const allFieldsMap = new Map<string, ResolvedFieldMeta>();\n\n // Helper to extract fields from a sub-schema\n const extractSubFields = (subSchema: z.ZodType | undefined) => {\n if (!subSchema) return;\n\n const extracted = extractFields(subSchema as ArgsSchema);\n for (const field of extracted.fields) {\n if (!allFieldsMap.has(field.name)) {\n allFieldsMap.set(field.name, field);\n }\n }\n };\n\n extractSubFields(left);\n extractSubFields(right);\n\n const description = extractDescription(schema);\n return {\n fields: Array.from(allFieldsMap.values()),\n schema: schema as ArgsSchema,\n schemaType: \"intersection\",\n unknownKeysMode: getUnknownKeysMode(schema),\n ...(description ? { description } : {}),\n };\n}\n\n/**\n * Extract all fields from a schema\n *\n * @param schema - The args schema (ZodObject, ZodDiscriminatedUnion, etc.)\n * @returns Extracted field information\n */\nexport function extractFields(schema: ArgsSchema): ExtractedFields {\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n switch (typeName) {\n case \"object\": {\n const description = extractDescription(schema);\n return {\n fields: extractFromObject(schema),\n schema,\n schemaType: \"object\",\n unknownKeysMode: getUnknownKeysMode(schema),\n ...(description ? { description } : {}),\n };\n }\n\n case \"union\":\n // In Zod v4, discriminatedUnion has type \"union\" with a discriminator property\n if (def?.discriminator) {\n return extractFromDiscriminatedUnion(schema);\n }\n return extractFromUnionLike(schema, \"union\");\n\n case \"xor\":\n return extractFromUnionLike(schema, \"xor\");\n\n case \"intersection\":\n return extractFromIntersection(schema);\n\n default: {\n const description = extractDescription(schema);\n // Fallback: try to treat as object\n return {\n fields: [],\n schema,\n schemaType: \"object\",\n unknownKeysMode: getUnknownKeysMode(schema),\n ...(description ? { description } : {}),\n };\n }\n }\n}\n\n/**\n * Get extracted fields from a command\n *\n * @param command - The command to extract fields from\n * @returns Extracted field information, or null if command has no args schema\n */\nexport function getExtractedFields(command: AnyCommand): ExtractedFields | null {\n if (!command.args) {\n return null;\n }\n return extractFields(command.args);\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"schema-extractor-B9D3Rf22.cjs","names":["z","getArgMeta","getArgMetaFromRegistry"],"sources":["../src/core/arg-registry.ts","../src/core/schema-extractor.ts"],"sourcesContent":["import { z } from \"zod\";\n\n/**\n * Base metadata shared by all argument types\n */\nexport interface BaseArgMeta {\n /** Argument description */\n description?: string;\n /** Treat as positional argument */\n positional?: boolean;\n /** Placeholder for help display */\n placeholder?: string;\n /**\n * Environment variable name(s) to read value from.\n * If an array is provided, earlier entries take priority.\n * CLI arguments always take precedence over environment variables.\n *\n * @example\n * ```ts\n * // Single env var\n * port: arg(z.coerce.number(), { env: \"PORT\" })\n *\n * // Multiple env vars (PORT takes priority over SERVER_PORT)\n * port: arg(z.coerce.number(), { env: [\"PORT\", \"SERVER_PORT\"] })\n * ```\n */\n env?: string | string[];\n}\n\n/**\n * Metadata for regular arguments (non-builtin aliases)\n */\nexport interface RegularArgMeta extends BaseArgMeta {\n /** Short alias (e.g., 'v' for --verbose) */\n alias?: string;\n}\n\n/**\n * Metadata for overriding built-in aliases (-h, -H)\n */\nexport interface BuiltinOverrideArgMeta extends BaseArgMeta {\n /** Built-in alias to override ('h' or 'H') */\n alias: \"h\" | \"H\";\n /** Must be true to override built-in aliases */\n overrideBuiltinAlias: true;\n}\n\n/**\n * Metadata options for argument definition\n */\nexport type ArgMeta = RegularArgMeta | BuiltinOverrideArgMeta;\n\n/**\n * Custom registry for politty argument metadata\n * This avoids polluting Zod's GlobalMeta\n */\nexport const argRegistry = z.registry<ArgMeta>();\n\n/**\n * Register metadata for a Zod schema\n *\n * @param schema - The Zod schema\n * @param meta - Argument metadata\n * @returns The same schema (for chaining)\n *\n * @example\n * ```ts\n * import { z } from \"zod\";\n * import { arg, defineCommand } from \"politty\";\n *\n * const cmd = defineCommand({\n * args: z.object({\n * name: arg(z.string(), { description: \"User name\", positional: true }),\n * verbose: arg(z.boolean().default(false), { alias: \"v\" }),\n * }),\n * run: (args) => {\n * console.log(args.name, args.verbose);\n * },\n * });\n * ```\n */\n/**\n * Type helper to validate ArgMeta\n * Forces a type error if alias is \"h\" or \"H\" without overrideBuiltinAlias: true\n */\ntype ValidateArgMeta<M> = M extends { alias: \"h\" | \"H\" }\n ? M extends { overrideBuiltinAlias: true }\n ? M\n : {\n [K in keyof M]: M[K];\n } & {\n __typeError: \"Alias 'h' or 'H' requires overrideBuiltinAlias: true\";\n }\n : M;\n\nexport function arg<T extends z.ZodType>(schema: T): T;\nexport function arg<T extends z.ZodType, M extends ArgMeta>(schema: T, meta: ValidateArgMeta<M>): T;\nexport function arg<T extends z.ZodType, M extends ArgMeta>(\n schema: T,\n meta?: ValidateArgMeta<M>,\n): T {\n if (meta) {\n argRegistry.add(schema, meta as ArgMeta);\n }\n return schema;\n}\n\n/**\n * Get metadata for a schema from the registry\n *\n * @param schema - The Zod schema\n * @returns The metadata if registered, undefined otherwise\n */\nexport function getArgMeta(schema: z.ZodType): ArgMeta | undefined {\n return argRegistry.get(schema);\n}\n","import { z } from \"zod\";\nimport type { AnyCommand, ArgsSchema } from \"../types.js\";\nimport { getArgMeta as getArgMetaFromRegistry, type ArgMeta } from \"./arg-registry.js\";\n\n/**\n * Get ArgMeta from both the custom registry and Zod's _def\n * Priority: custom registry > _def.argMeta\n */\nfunction getArgMeta(schema: z.ZodType): ArgMeta | undefined {\n // First check custom registry\n const fromRegistry = getArgMetaFromRegistry(schema);\n if (fromRegistry) return fromRegistry;\n // Check Zod native meta\n // Some Zod versions or extensions use a global registry accessed via .meta()\n if (typeof (schema as any).meta === \"function\") {\n const meta = (schema as any).meta();\n if (meta && typeof meta === \"object\") {\n return meta as ArgMeta;\n }\n }\n\n // Then check _def.argMeta (for augmented Zod types)\n const def = (schema as any)._def;\n if (def?.argMeta) return def.argMeta;\n\n // Also check _def.meta just in case\n if (def?.meta) return def.meta as ArgMeta;\n\n return undefined;\n}\n\n/**\n * Resolved metadata for an argument field\n */\nexport interface ResolvedFieldMeta {\n /** Field name (camelCase, as defined in schema) */\n name: string;\n /** CLI option name (kebab-case, for command line usage) */\n cliName: string;\n /** Short alias (e.g., 'v' for --verbose) */\n alias?: string | undefined;\n /** Argument description */\n description?: string | undefined;\n /** Whether this is a positional argument */\n positional: boolean;\n /** Placeholder for help display */\n placeholder?: string | undefined;\n /**\n * Environment variable name(s) to read value from.\n * If an array, earlier entries take priority.\n */\n env?: string | string[] | undefined;\n /** Whether this argument is required */\n required: boolean;\n /** Default value if any */\n defaultValue?: unknown;\n /** Detected type from schema */\n type: \"string\" | \"number\" | \"boolean\" | \"array\" | \"unknown\";\n /** Original Zod schema */\n schema: z.ZodType;\n /** True if this overrides built-in aliases (-h, -H) */\n overrideBuiltinAlias?: true;\n}\n\n/**\n * Extracted fields from a schema\n */\nexport interface ExtractedFields {\n /** All field definitions */\n fields: ResolvedFieldMeta[];\n /** Original schema for validation */\n schema: ArgsSchema;\n /** Schema type */\n schemaType: \"object\" | \"discriminatedUnion\" | \"union\" | \"xor\" | \"intersection\";\n /** Discriminator key (for discriminatedUnion) */\n discriminator?: string;\n /** Variants (for discriminatedUnion) */\n variants?: Array<{\n discriminatorValue: string;\n fields: ResolvedFieldMeta[];\n description?: string;\n }>;\n /** Options (for union) */\n unionOptions?: ExtractedFields[];\n /** Schema description */\n description?: string;\n /**\n * Unknown keys handling mode\n * - \"strict\": Unknown keys cause validation errors (z.strictObject or z.object().strict())\n * - \"strip\": Unknown keys trigger warnings (default, z.object())\n * - \"passthrough\": Unknown keys are silently ignored (z.looseObject or z.object().passthrough())\n */\n unknownKeysMode: UnknownKeysMode;\n}\n\n/**\n * Unknown keys handling mode for object schemas\n * - \"strict\": Unknown keys cause validation errors\n * - \"strip\": Unknown keys are silently ignored (default)\n * - \"passthrough\": Unknown keys are passed through\n */\nexport type UnknownKeysMode = \"strict\" | \"strip\" | \"passthrough\";\n\n// Internal type for accessing zod v4 internals\ninterface ZodV4Def {\n type?: string;\n innerType?: z.ZodType;\n schema?: z.ZodType;\n defaultValue?: unknown;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n shape?: Record<string, any>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n options?: any[];\n discriminator?: string;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n left?: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n right?: any;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n catchall?: any;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype ZodSchemaWithDef = z.ZodType & { def?: ZodV4Def; _def?: ZodV4Def; type?: string; shape?: any };\n\n/**\n * Get the type name from a zod schema (v4 compatible)\n */\nfunction getTypeName(schema: z.ZodType): string | undefined {\n const s = schema as ZodSchemaWithDef;\n return s.def?.type ?? s._def?.type ?? s.type;\n}\n\n/**\n * Detect unknown keys handling mode from a Zod object schema\n *\n * In Zod v4:\n * - Default (strip): _def.catchall is undefined\n * - strict: _def.catchall is ZodNever (type = \"never\")\n * - passthrough: _def.catchall is ZodUnknown (type = \"unknown\")\n */\nexport function getUnknownKeysMode(schema: z.ZodType): UnknownKeysMode {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const catchall = def?.catchall;\n\n if (!catchall) {\n // Default behavior: strip unknown keys (but we want to warn)\n return \"strip\";\n }\n\n const catchallType = getTypeName(catchall);\n\n if (catchallType === \"never\") {\n // z.strictObject() or z.object().strict() - reject unknown keys\n return \"strict\";\n }\n\n if (catchallType === \"unknown\" || catchallType === \"any\") {\n // z.looseObject() or z.object().passthrough() - allow unknown keys\n return \"passthrough\";\n }\n\n // Unknown catchall type, default to strip behavior\n return \"strip\";\n}\n\n/**\n * Get the inner schema, unwrapping optional, nullable, default, etc.\n */\nfunction unwrapSchema(schema: z.ZodType): z.ZodType {\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n if (typeName === \"optional\" || typeName === \"nullable\" || typeName === \"default\") {\n const innerSchema = def?.innerType;\n if (innerSchema) {\n return unwrapSchema(innerSchema);\n }\n }\n\n // Handle effects (transform, refine, etc.)\n if (typeName === \"pipe\") {\n const innerSchema = def?.schema;\n if (innerSchema) {\n return unwrapSchema(innerSchema);\n }\n }\n\n return schema;\n}\n\n/**\n * Detect the base type of a schema\n */\nfunction detectType(schema: z.ZodType): \"string\" | \"number\" | \"boolean\" | \"array\" | \"unknown\" {\n const innerSchema = unwrapSchema(schema);\n const typeName = getTypeName(innerSchema);\n\n switch (typeName) {\n case \"string\":\n return \"string\";\n case \"number\":\n case \"int\":\n return \"number\";\n case \"boolean\":\n return \"boolean\";\n case \"array\":\n return \"array\";\n default:\n return \"unknown\";\n }\n}\n\n/**\n * Convert camelCase to kebab-case\n * @example toKebabCase(\"dryRun\") => \"dry-run\"\n * @example toKebabCase(\"outputDir\") => \"output-dir\"\n * @example toKebabCase(\"XMLParser\") => \"xml-parser\"\n */\nexport function toKebabCase(str: string): string {\n return str\n .replace(/([a-z])([A-Z])/g, \"$1-$2\")\n .replace(/([A-Z]+)([A-Z][a-z])/g, \"$1-$2\")\n .toLowerCase();\n}\n\n/**\n * Check if a schema is required (not optional or has default)\n *\n * Note: We only check isOptional(), not isNullable(), because CLI arguments\n * are either present (string value) or absent (undefined), never null.\n * Also, some coerce types incorrectly report isNullable()=true.\n */\nfunction isRequired(schema: z.ZodType): boolean {\n return !schema.isOptional();\n}\n\n/**\n * Extract default value from schema if present\n */\nfunction extractDefaultValue(schema: z.ZodType): unknown {\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n if (typeName === \"default\") {\n const defaultValue = def?.defaultValue;\n // In zod v4, defaultValue can be a direct value or a function\n if (typeof defaultValue === \"function\") {\n return defaultValue();\n }\n return defaultValue;\n }\n\n // Check for nested default in optional/nullable\n if (typeName === \"optional\" || typeName === \"nullable\") {\n const innerSchema = def?.innerType;\n if (innerSchema) {\n return extractDefaultValue(innerSchema);\n }\n }\n\n return undefined;\n}\n\n/**\n * Extract description from schema\n */\nfunction extractDescription(schema: z.ZodType): string | undefined {\n // Check direct description\n if (schema.description) {\n return schema.description;\n }\n\n // Check inner schema for wrapped types\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n if (typeName === \"optional\" || typeName === \"nullable\" || typeName === \"default\") {\n const innerSchema = def?.innerType;\n if (innerSchema) {\n return extractDescription(innerSchema);\n }\n }\n\n return undefined;\n}\n\n/**\n * Resolve field metadata from schema and argRegistry\n */\nfunction resolveFieldMeta(name: string, schema: z.ZodType): ResolvedFieldMeta {\n // Get metadata from argRegistry\n const argMeta = getArgMeta(schema) ?? getArgMeta(unwrapSchema(schema));\n\n // Priority: argRegistry > schema.describe()\n const description = argMeta?.description ?? extractDescription(schema);\n\n // Convert camelCase field name to kebab-case for CLI usage\n const cliName = toKebabCase(name);\n\n const meta: ResolvedFieldMeta = {\n name,\n cliName,\n alias: argMeta?.alias,\n description,\n positional: argMeta?.positional ?? false,\n placeholder: argMeta?.placeholder,\n env: argMeta?.env,\n required: isRequired(schema),\n defaultValue: extractDefaultValue(schema),\n type: detectType(schema),\n schema,\n };\n\n // Add overrideBuiltinAlias only if it's true\n if (argMeta && \"overrideBuiltinAlias\" in argMeta && argMeta.overrideBuiltinAlias === true) {\n meta.overrideBuiltinAlias = true;\n }\n\n return meta;\n}\n\n/**\n * Get shape from a ZodObject\n */\nfunction getObjectShape(schema: z.ZodType): Record<string, z.ZodType> {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n return def?.shape ?? s.shape ?? {};\n}\n\n/**\n * Extract fields from a ZodObject\n */\nfunction extractFromObject(schema: z.ZodType): ResolvedFieldMeta[] {\n const shape = getObjectShape(schema);\n return Object.entries(shape).map(([name, fieldSchema]) => resolveFieldMeta(name, fieldSchema));\n}\n\n/**\n * Extract fields from a discriminated union\n */\nfunction extractFromDiscriminatedUnion(schema: z.ZodType): ExtractedFields {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const discriminator = def?.discriminator ?? \"\";\n const options = def?.options ?? [];\n\n // Collect all unique fields across all variants\n const allFieldsMap = new Map<string, ResolvedFieldMeta>();\n const variants: ExtractedFields[\"variants\"] = [];\n\n for (const option of options) {\n const shape = getObjectShape(option as z.ZodObject<z.ZodRawShape>);\n const variantFields: ResolvedFieldMeta[] = [];\n\n // Get discriminator value\n let discriminatorValue = \"\";\n const discriminatorSchema = shape[discriminator];\n if (discriminatorSchema) {\n const typeName = getTypeName(discriminatorSchema);\n if (typeName === \"literal\") {\n const litDef =\n (discriminatorSchema as ZodSchemaWithDef).def ??\n (discriminatorSchema as ZodSchemaWithDef)._def;\n // In Zod v4, literal values are in _def.values array\n const value = (litDef as { value?: unknown; values?: unknown[] })?.value;\n const values = (litDef as { value?: unknown; values?: unknown[] })?.values;\n discriminatorValue = String(value ?? values?.[0] ?? \"\");\n }\n }\n\n for (const [name, fieldSchema] of Object.entries(shape)) {\n const fieldMeta = resolveFieldMeta(name, fieldSchema);\n variantFields.push(fieldMeta);\n\n // Add to all fields map (first occurrence wins for metadata)\n if (!allFieldsMap.has(name)) {\n allFieldsMap.set(name, fieldMeta);\n }\n }\n\n // Extract description from the variant option\n const variantDescription = extractDescription(option as z.ZodType);\n\n variants.push({\n discriminatorValue,\n fields: variantFields,\n ...(variantDescription ? { description: variantDescription } : {}),\n });\n }\n\n const description = extractDescription(schema);\n return {\n fields: Array.from(allFieldsMap.values()),\n schema: schema as ArgsSchema,\n schemaType: \"discriminatedUnion\",\n unknownKeysMode: getUnknownKeysMode(schema),\n discriminator,\n variants,\n ...(description ? { description } : {}),\n };\n}\n\n/**\n * Extract fields from a union-like schema (union or xor)\n */\nfunction extractFromUnionLike(schema: z.ZodType, schemaType: \"union\" | \"xor\"): ExtractedFields {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const options = def?.options ?? [];\n\n // Collect all unique fields across all options\n const allFieldsMap = new Map<string, ResolvedFieldMeta>();\n const unionOptions: ExtractedFields[] = [];\n\n for (const option of options) {\n // Extract fields for this option recursively\n // We cast to ArgsSchema because we expect options to be objects or other supported types\n const extracted = extractFields(option as ArgsSchema);\n unionOptions.push(extracted);\n\n // Add to combined fields map\n for (const field of extracted.fields) {\n if (!allFieldsMap.has(field.name)) {\n allFieldsMap.set(field.name, field);\n }\n }\n }\n\n const description = extractDescription(schema);\n return {\n fields: Array.from(allFieldsMap.values()),\n schema: schema as ArgsSchema,\n schemaType,\n unknownKeysMode: getUnknownKeysMode(schema),\n unionOptions,\n ...(description ? { description } : {}),\n };\n}\n\n/**\n * Extract fields from an intersection\n */\nfunction extractFromIntersection(schema: z.ZodType): ExtractedFields {\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n const left = def?.left;\n const right = def?.right;\n\n const allFieldsMap = new Map<string, ResolvedFieldMeta>();\n\n // Helper to extract fields from a sub-schema\n const extractSubFields = (subSchema: z.ZodType | undefined) => {\n if (!subSchema) return;\n\n const extracted = extractFields(subSchema as ArgsSchema);\n for (const field of extracted.fields) {\n if (!allFieldsMap.has(field.name)) {\n allFieldsMap.set(field.name, field);\n }\n }\n };\n\n extractSubFields(left);\n extractSubFields(right);\n\n const description = extractDescription(schema);\n return {\n fields: Array.from(allFieldsMap.values()),\n schema: schema as ArgsSchema,\n schemaType: \"intersection\",\n unknownKeysMode: getUnknownKeysMode(schema),\n ...(description ? { description } : {}),\n };\n}\n\n/**\n * Extract all fields from a schema\n *\n * @param schema - The args schema (ZodObject, ZodDiscriminatedUnion, etc.)\n * @returns Extracted field information\n */\nexport function extractFields(schema: ArgsSchema): ExtractedFields {\n const typeName = getTypeName(schema);\n const s = schema as ZodSchemaWithDef;\n const def = s.def ?? s._def;\n\n switch (typeName) {\n case \"object\": {\n const description = extractDescription(schema);\n return {\n fields: extractFromObject(schema),\n schema,\n schemaType: \"object\",\n unknownKeysMode: getUnknownKeysMode(schema),\n ...(description ? { description } : {}),\n };\n }\n\n case \"union\":\n // In Zod v4, discriminatedUnion has type \"union\" with a discriminator property\n if (def?.discriminator) {\n return extractFromDiscriminatedUnion(schema);\n }\n return extractFromUnionLike(schema, \"union\");\n\n case \"xor\":\n return extractFromUnionLike(schema, \"xor\");\n\n case \"intersection\":\n return extractFromIntersection(schema);\n\n default: {\n const description = extractDescription(schema);\n // Fallback: try to treat as object\n return {\n fields: [],\n schema,\n schemaType: \"object\",\n unknownKeysMode: getUnknownKeysMode(schema),\n ...(description ? { description } : {}),\n };\n }\n }\n}\n\n/**\n * Get extracted fields from a command\n *\n * @param command - The command to extract fields from\n * @returns Extracted field information, or null if command has no args schema\n */\nexport function getExtractedFields(command: AnyCommand): ExtractedFields | null {\n if (!command.args) {\n return null;\n }\n return extractFields(command.args);\n}\n"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"schema-extractor-CXeUTW_Z.d.cts","names":[],"sources":["../src/types.ts","../src/core/schema-extractor.ts"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"schema-extractor-Cl_D04BX.d.ts","names":[],"sources":["../src/types.ts","../src/core/schema-extractor.ts"],"mappings":";;;;;AAKA;UAAiB,OAAA;;EAEf,GAAA;EAAA;EAEA,IAAA;EAEA;EAAA,MAAA;AAAA;AAOF;;;;AAAA,UAAiB,MAAA;EAEX;EAAJ,GAAA,CAAI,OAAA;EAEE;EAAN,KAAA,CAAM,OAAA;AAAA;AAOR;;;AAAA,KAAY,UAAA,GAAa,CAAA,CAAE,OAAA,CAAQ,MAAA;;;;UAKlB,YAAA;EALwB;EAOvC,IAAA,EAAM,KAAA;AAAA;;;;UAMS,cAAA;EANT;EAQN,IAAA,EAAM,KAAA;EARK;EAUX,KAAA,GAAQ,KAAA;AAAA;;;;;;UAQO,WAAA,qBACK,UAAA;EATZ;EAaR,IAAA;EAba;EAeb,WAAA;EAP0B;EAS1B,IAAA,EAAM,WAAA;EARc;EAUpB,WAAA,GAAc,iBAAA;EAAA;EAEd,KAAA,KAAU,OAAA,EAAS,YAAA,CAAa,KAAA,aAAkB,OAAA;EAA/B;EAEnB,OAAA,KAAY,OAAA,EAAS,cAAA,CAAe,KAAA,aAAkB,OAAA;EAAlB;EAEpC,KAAA;EAFsD;EAItD,QAAA,GAAW,OAAA;AAAA;;;;;;;UASI,eAAA,qBACK,UAAA,sEAGZ,WAAA,CAAY,WAAA,EAAa,KAAA;EAvB3B;EAyBN,GAAA,GAAM,IAAA,EAAM,KAAA,KAAU,OAAA;AAAA;;;;;;UAQP,kBAAA,qBACK,UAAA,mDAEZ,WAAA,CAAY,WAAA,EAAa,KAAA;EA9BZ;EAgCrB,GAAA;AAAA;;;;KAMU,OAAA,qBACU,UAAA,gEAGlB,eAAA,CAAgB,WAAA,EAAa,KAAA,EAAO,OAAA,IAAW,kBAAA,CAAmB,WAAA,EAAa,KAAA;;;AA7BnF;;;;KAsCK,OAAA;;;;;KAOA,SAAA;;;;;KAMO,UAAA,GAAa,OAAA,CAAQ,UAAA,cAAwB,OAAA,EAAS,SAAA;;;;KAKtD,eAAA,GAAkB,UAAA,UAAoB,OAAA,CAAQ,UAAA;;;;KAK9C,iBAAA,GAAoB,MAAA,SAAe,eAAA;;AA/C/C;;UAoDiB,WAAA;EAnDK;EAqDpB,OAAA;EAnDiC;EAqDjC,KAAA;EArDmB;EAuDnB,WAAA;EAzDA;EA2DA,cAAA;EA1DA;EA4DA,MAAA,GAAS,MAAA;AAAA;;;;UAMM,iBAAA;EAzDL;EA2DV,KAAA;EA3DiB;EA6DjB,WAAA;EAzDkB;EA2DlB,cAAA;EA3DsC;EA6DtC,MAAA,GAAS,MAAA;AAAA;AApDC;;;AAAA,KAiFA,QAAA;;AApEZ;;KAyEY,SAAA;;;;UAKK,QAAA;EA9Ee;EAgF9B,OAAA;EAhFuB;EAkFvB,SAAA,EAAW,IAAA;EAlF4C;EAoFvD,KAAA,EAAO,QAAA;EApFkE;EAsFzE,MAAA,EAAQ,SAAA;AAAA;;;;UAMO,aAAA;EAvFiC;EAyFhD,OAAA,EAAS,QAAA;AAAA;;;;UAMM,gBAAA;EA/FmD;EAiGlE,OAAA;EA5F2B;EA8F3B,MAAA,EAAQ,CAAA;EA9FsB;EAgG9B,KAAA;EA3Fe;EA6Ff,QAAA;;EAEA,IAAA,EAAM,aAAA;AAAA;;;;UAMS,gBAAA;EA3FN;EA6FT,OAAA;EA7Fe;EA+Ff,MAAA;EAzFgC;EA2FhC,KAAA,EAAO,KAAA;EAnFQ;EAqFf,QAAA;EAzFA;EA2FA,IAAA,EAAM,aAAA;AAAA;;;;KAMI,SAAA,gBAAyB,gBAAA,CAAiB,CAAA,IAAK,gBAAA;;;;AApQ3D;;UC6BiB,iBAAA;ED7BO;EC+BtB,IAAA;ED3BA;EC6BA,OAAA;ED3BM;EC6BN,KAAA;EDtBe;ECwBf,WAAA;;EAEA,UAAA;EDxBA;EC0BA,WAAA;EDxBA;;;;EC6BA,GAAA;EDtBoB;ECwBpB,QAAA;EDxBgC;EC0BhC,YAAA;ED1ByB;EC4BzB,IAAA;ED5BuC;EC8BvC,MAAA,EAAQ,CAAA,CAAE,OAAA;EDzBK;EC2Bf,oBAAA;AAAA;;;;UAMe,eAAA;ED/BJ;ECiCX,MAAA,EAAQ,iBAAA;ED3BO;EC6Bf,MAAA,EAAQ,UAAA;ED7BqB;EC+B7B,UAAA;ED/B8B;ECiC9B,aAAA;ED/BM;ECiCN,QAAA,GAAW,KAAA;IACT,kBAAA;IACA,MAAA,EAAQ,iBAAA;IACR,WAAA;EAAA;ED1BwB;EC6B1B,YAAA,GAAe,eAAA;ED5BK;EC8BpB,WAAA;EDpBc;;;;;;EC2Bd,eAAA,EAAiB,eAAA;AAAA;;;;;;;KASP,eAAA;;;;;;;;;iBAwCI,kBAAA,CAAmB,MAAA,EAAQ,CAAA,CAAE,OAAA,GAAU,eAAA;;;;;;;iBAgFvC,WAAA,CAAY,GAAA;;;;AD3I5B;;;iBCqZgB,aAAA,CAAc,MAAA,EAAQ,UAAA,GAAa,eAAA"}