From 31a9512fe8d59a1809800f7cb54c329f593af2b4 Mon Sep 17 00:00:00 2001 From: Andrey Luiz Date: Mon, 9 Dec 2024 08:10:19 +0100 Subject: [PATCH 1/2] TLS-14 Sir to JavaScript --- package.json | 7 +- sample.json | 67 --- sample.sia | 54 +- src/cli.ts | 51 -- src/cli/common/index.ts | 45 ++ src/cli/common/js/index.ts | 86 +++ src/cli/common/js/maps.ts | 53 ++ src/cli/common/js/strings.ts | 52 ++ src/cli/common/types.ts | 41 ++ src/cli/index.ts | 58 ++ src/cli/javascript.ts | 151 ++++++ src/utils/log.ts | 14 +- src/visitor.ts | 2 + yarn.lock | 998 ++++++++++++++++++++++++++++++++++- 14 files changed, 1530 insertions(+), 149 deletions(-) delete mode 100644 sample.json delete mode 100644 src/cli.ts create mode 100644 src/cli/common/index.ts create mode 100644 src/cli/common/js/index.ts create mode 100644 src/cli/common/js/maps.ts create mode 100644 src/cli/common/js/strings.ts create mode 100644 src/cli/common/types.ts create mode 100644 src/cli/index.ts create mode 100644 src/cli/javascript.ts diff --git a/package.json b/package.json index 6caed21..ca5f22f 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "commander": "^12.1.0" }, "bin": { - "sia": "dist/cli.js" + "sia": "dist/cli/index.js" }, "devDependencies": { "@eslint/js": "^9.16.0", @@ -16,14 +16,15 @@ "eslint-config-prettier": "^9.1.0", "eslint-plugin-prettier": "^5.2.1", "globals": "^15.13.0", - "prettier": "^3.4.1", + "prettier": "^3.4.2", + "tsx": "^4.19.2", "typescript": "^5.7.2", "typescript-eslint": "^8.17.0" }, "type": "module", "scripts": { "build": "tsc", - "start": "node dist/index.js", + "start": "tsx src/cli/index.ts", "lint": "eslint src/**/*.ts", "format": "prettier --write .", "ts-check": "tsc --noEmit" diff --git a/sample.json b/sample.json deleted file mode 100644 index a4a2ac7..0000000 --- a/sample.json +++ /dev/null @@ -1,67 +0,0 @@ -[ - { - "name": "Person", - "type": "schema", - "fields": [ - { - "name": "name", - "type": "text" - }, - { - "name": "age", - "type": "int32", - "optional": true, - "min": 0, - "max": 120 - }, - { - "name": "email", - "type": "text", - "optional": true, - "encoding": "ascii" - }, - { - "name": "tags", - "type": "text", - "isArray": true - }, - { - "name": "address", - "type": "Address" - } - ] - }, - { - "name": "Address", - "type": "schema", - "fields": [ - { - "name": "street", - "type": "text", - "defaultValue": "Default Street" - }, - { - "name": "city", - "type": "text" - }, - { - "name": "zip", - "type": "int32" - } - ] - }, - { - "name": "add", - "type": "function", - "fields": [ - { - "name": "lhs", - "type": "int32" - }, - { - "name": "rhs", - "type": "int32" - } - ] - } -] diff --git a/sample.sia b/sample.sia index 81da1d5..ec8c241 100644 --- a/sample.sia +++ b/sample.sia @@ -1,18 +1,50 @@ schema Person { - name text - age? int32(min = 0, max = 120) - email? text(encoding = "ascii") - tags text[] + name string8 + age? string(min = 0, max = 120) + ageNumber? int32 + email? string8(encoding = "ascii") + ageArray? int8[] + ageArray2? int16[] + ageArray3? int32[] + ageArray4? int64[] + footSizeArray? uint8[] + footSizeArray2? uint16[] + footSizeArray3? uint32[] + footSizeArray4? uint64[] + tags8 string8[] + tags16 string16[] + tags32 string32[] + tags64 string64[] + tagsByteArray8 byte8[] + tagsByteArray16 byte16[] + tagsByteArray32 byte32[] + tagsByteArray64 byte64[] + tagsBool bool[] + tagsBigInt bigint[] + tagsArray8 array8[] + tagsArray16 array16[] + tagsArray32 array32[] + tagsArray64 array64[] address Address + isAdmin bool + billingInfo? BillingInfo } schema Address { - street text = "Default Street" - city text - zip int32 + street string8 = "Default Street" + city string8 + zip string(min = 5, max = 5) + country Country } -function add returns int64 { - lhs int32 - rhs int32 -} \ No newline at end of file +schema Country { + name string8 + code string(min = 2, max = 2) + codeArray string8[] + flag string8 +} + +schema BillingInfo { + cardNumber string8 + expiryDate string8 +} diff --git a/src/cli.ts b/src/cli.ts deleted file mode 100644 index 2dbea7e..0000000 --- a/src/cli.ts +++ /dev/null @@ -1,51 +0,0 @@ -#!/usr/bin/env node - -import { Command } from "commander"; -import { readFileSync, writeFileSync } from "fs"; -import { compile } from "./index.js"; -import { logError } from "./utils/log.js"; - -import { ILexingError, IRecognitionException } from "chevrotain"; - -const program = new Command(); - -program - .name("sia") - .description("A schema compiler for the fastest serializing library.") - .version("1.0.0"); - -program - .command("compile") - .description("Compile a .sia file") - .argument("", "file to compile") - .option("-s, --string", "display the result as a string") - .option("-o, --output ", "output the result to a file") - .action(async (file, options) => { - const src = readFileSync(file, "utf-8"); - try { - const result = compile(src); - - if (options.string) { - try { - return console.log(JSON.stringify(result, null, 2)); - } catch (error) { - console.error(error); - process.exitCode = 1; - return; - } - } - - if (options.output) { - writeFileSync(options.output, JSON.stringify(result, null, 2)); - console.log(`Output written to ${options.output}`); - return; - } - - return console.dir(result, { depth: null }); - } catch (error) { - logError(src, file, error as ILexingError | IRecognitionException); - process.exitCode = 1; - } - }); - -program.parse(); diff --git a/src/cli/common/index.ts b/src/cli/common/index.ts new file mode 100644 index 0000000..43be021 --- /dev/null +++ b/src/cli/common/index.ts @@ -0,0 +1,45 @@ +import { SchemaDefinition } from "../../visitor.js"; +import { generateJs, isJsProject } from "../javascript.js"; +import { Extension } from "./types.js"; + +export const getExtension = (extension?: string) => { + if (extension && !Object.values(Extension).includes(extension as Extension)) { + return null; + } + + // TODO: Add Ts, Go and Python support + if (!extension) { + if (isJsProject()) { + return Extension.JS; + } + } + + return extension as Extension; +}; + +export const generateSia = (sir: SchemaDefinition[], extension: Extension) => { + const schemas = sir.filter((s) => s.type === "schema"); + const functions = sir.filter((s) => s.type === "function"); + + if (functions.length > 0) { + console.warn("Functions are not yet supported."); + } + + let processor = null; + + switch (extension) { + case Extension.JS: + processor = generateJs; + break; + } + + if (!processor) { + throw new Error(`Unsupported extension: ${extension}`); + } + + return processor(schemas); +}; + +export const createLineBreakString = (count: number = 1) => { + return "\n".repeat(count); +}; diff --git a/src/cli/common/js/index.ts b/src/cli/common/js/index.ts new file mode 100644 index 0000000..f4a4ef9 --- /dev/null +++ b/src/cli/common/js/index.ts @@ -0,0 +1,86 @@ +import { FieldDefinition, SchemaDefinition } from "../../../visitor.js"; +import { SiaType } from "../types.js"; +import { siaTypeSerializerArrayItemMap } from "./maps.js"; +import { createAttributeString } from "./strings.js"; + +export const isAnyString = (type: SiaType) => { + return [ + SiaType.String8, + SiaType.String16, + SiaType.String32, + SiaType.String64, + ].includes(type); +}; + +export const getStringTypeFromLength = (max: number = 255) => { + if (max <= 255) return SiaType.String8; + if (max <= 65535) return SiaType.String16; + if (max <= 4294967295) return SiaType.String32; + return SiaType.String64; +}; + +export const getRequiredSerializers = (schemas: SchemaDefinition[]) => { + return Array.from( + new Set( + schemas + .map((schema) => schema.fields.filter((field) => field.isArray)) + .flat() + .filter(Boolean) + .map( + (field) => + siaTypeSerializerArrayItemMap[ + field.type as keyof typeof siaTypeSerializerArrayItemMap + ], + ), + ), + ); +}; + +export const getDefaultValueForType = ( + field: SchemaDefinition["fields"][0], +): string => { + if (field.defaultValue) { + return `"${field.defaultValue}"`; + } + + if (field.type.startsWith("int") || field.type.startsWith("uint")) { + return "0"; + } + + if (field.type === "bool") { + return "false"; + } + + return '""'; +}; + +export const generateAttribute = ( + field: FieldDefinition, + schemas: SchemaDefinition[], +): string => { + if (field.isArray) { + return createAttributeString(field.name, "[]"); + } + + if (!Object.values(SiaType).includes(field.type as SiaType)) { + return generateNestedObjectAttribute(field, schemas); + } + + return createAttributeString(field.name, getDefaultValueForType(field)); +}; + +export const generateNestedObjectAttribute = ( + field: SchemaDefinition["fields"][0], + schemas: SchemaDefinition[], +): string => { + const referencedSchema = schemas.find((s) => s.name === field.type); + if (!referencedSchema) { + throw new Error(`Referenced schema ${field.type} not found`); + } + + const nestedFields = referencedSchema.fields + .map((nestedField) => generateAttribute(nestedField, schemas)) + .join("\n"); + + return createAttributeString(field.name, `{\n${nestedFields}\n}`); +}; diff --git a/src/cli/common/js/maps.ts b/src/cli/common/js/maps.ts new file mode 100644 index 0000000..b781d1b --- /dev/null +++ b/src/cli/common/js/maps.ts @@ -0,0 +1,53 @@ +import { SiaType } from "../types.js"; + +export const siaTypeFunctionMap: Record = { + [SiaType.Int8]: "addInt8", + [SiaType.Int16]: "addInt16", + [SiaType.Int32]: "addInt32", + [SiaType.Int64]: "addInt64", + [SiaType.UInt8]: "addUInt8", + [SiaType.UInt16]: "addUInt16", + [SiaType.UInt32]: "addUInt32", + [SiaType.UInt64]: "addUInt64", + [SiaType.String]: "addStringN", + [SiaType.String8]: "addString8", + [SiaType.String16]: "addString16", + [SiaType.String32]: "addString32", + [SiaType.String64]: "addString64", + [SiaType.ByteArray8]: "addByteArray8", + [SiaType.ByteArray16]: "addByteArray16", + [SiaType.ByteArray32]: "addByteArray32", + [SiaType.ByteArray64]: "addByteArray64", + [SiaType.Bool]: "addBool", + [SiaType.BigInt]: "addBigInt", + [SiaType.Array8]: "addArray8", + [SiaType.Array16]: "addArray16", + [SiaType.Array32]: "addArray32", + [SiaType.Array64]: "addArray64", +}; + +export const siaTypeSerializerArrayItemMap: Record = { + [SiaType.Int8]: "serializeInt8ArrayItem", + [SiaType.Int16]: "serializeInt16ArrayItem", + [SiaType.Int32]: "serializeInt32ArrayItem", + [SiaType.Int64]: "serializeInt64ArrayItem", + [SiaType.UInt8]: "serializeUInt8ArrayItem", + [SiaType.UInt16]: "serializeUInt16ArrayItem", + [SiaType.UInt32]: "serializeUInt32ArrayItem", + [SiaType.UInt64]: "serializeUInt64ArrayItem", + [SiaType.String]: "serializeStringArrayItem", + [SiaType.String8]: "serializeString8ArrayItem", + [SiaType.String16]: "serializeString16ArrayItem", + [SiaType.String32]: "serializeString32ArrayItem", + [SiaType.String64]: "serializeString64ArrayItem", + [SiaType.ByteArray8]: "serializeByteArray8ArrayItem", + [SiaType.ByteArray16]: "serializeByteArray16ArrayItem", + [SiaType.ByteArray32]: "serializeByteArray32ArrayItem", + [SiaType.ByteArray64]: "serializeByteArray64ArrayItem", + [SiaType.Bool]: "serializeBoolArrayItem", + [SiaType.BigInt]: "serializeBigIntArrayItem", + [SiaType.Array8]: "serializeArray8ArrayItem", + [SiaType.Array16]: "serializeArray16ArrayItem", + [SiaType.Array32]: "serializeArray32ArrayItem", + [SiaType.Array64]: "serializeArray64ArrayItem", +}; diff --git a/src/cli/common/js/strings.ts b/src/cli/common/js/strings.ts new file mode 100644 index 0000000..15ef7a2 --- /dev/null +++ b/src/cli/common/js/strings.ts @@ -0,0 +1,52 @@ +export const createAttributeString = (name: string, value: string) => { + return `${name}: ${value},`; +}; + +export const createSiaImportString = (imports: string[]) => { + if (imports.length === 0) { + return ""; + } + + return `import { ${imports.join(", ")} } from "sializer";`; +}; + +export const createSiaAddTypeFunctionCallString = ( + fn: string, + fieldName: string, + serializer?: string, +) => { + const serializerArg = serializer ? `, ${serializer}` : ""; + return `sia.${fn}(${fieldName}${serializerArg});\n`; +}; + +export const createIfConditionString = (condition: string, body: string) => { + return `if (${condition}) {\n${body}\n}\n`; +}; + +export const createCustomSerializerFunctionDeclarationString = ( + fnName: string, + signature: string, + body: string, +) => { + return `function ${fnName}(${signature}) {\n${body}return sia;\n}\n`; +}; + +export const createCustomSerializerFunctionCallString = ( + serializer: string, + siaInstance: string, + fieldName: string, +) => { + return `serialize${serializer}(${siaInstance}, ${fieldName});\n`; +}; + +export const createNamedObjectString = (name: string, body: string) => { + return `const ${name} = {\n${body}\n};\n`; +}; + +export const createSiaInstanceString = (schemaName: string) => { + return `const ${schemaName.toLowerCase()}Sia = new Sia();\n`; +}; + +export const createSiaResultString = (instanceName: string) => { + return `const result = ${instanceName}.content;`; +}; diff --git a/src/cli/common/types.ts b/src/cli/common/types.ts new file mode 100644 index 0000000..7b00e69 --- /dev/null +++ b/src/cli/common/types.ts @@ -0,0 +1,41 @@ +import { SchemaDefinition } from "../../visitor.js"; + +export enum SiaType { + Int8 = "int8", + Int16 = "int16", + Int32 = "int32", + Int64 = "int64", + UInt8 = "uint8", + UInt16 = "uint16", + UInt32 = "uint32", + UInt64 = "uint64", + String = "string", + String8 = "string8", + String16 = "string16", + String32 = "string32", + String64 = "string64", + ByteArray8 = "byte8", + ByteArray16 = "byte16", + ByteArray32 = "byte32", + ByteArray64 = "byte64", + Bool = "bool", + BigInt = "bigint", + Array8 = "array8", + Array16 = "array16", + Array32 = "array32", + Array64 = "array64", +} + +export enum Extension { + JS = "js", + TS = "ts", +} + +export interface Generator { + sir: SchemaDefinition[]; + imports: () => string; + types: () => string; + sampleObject: () => string; + siaInstance: () => string; + toString: () => string; +} diff --git a/src/cli/index.ts b/src/cli/index.ts new file mode 100644 index 0000000..a79c516 --- /dev/null +++ b/src/cli/index.ts @@ -0,0 +1,58 @@ +#!/usr/bin/env node + +import { ILexingError, IRecognitionException } from "chevrotain"; +import { Command } from "commander"; +import { readFileSync, writeFileSync } from "fs"; +import { compile } from "../index.js"; +import { logError } from "../utils/log.js"; +import { generateSia, getExtension } from "./common/index.js"; + +const program = new Command(); + +program + .name("sia") + .description("A schema compiler for the fastest serializing library.") + .version("1.0.0"); + +program + .command("compile") + .description("Compile a .sia file") + .argument("", "file to compile") + .option("-s, --generate-sir", "generate the sir file") + .option("-e, --extension ", "extension of the output file") + .action(async (file, options) => { + const extension = getExtension(options.extension); + + if (!extension) { + console.error("Invalid extension"); + process.exitCode = 1; + return; + } + + const src = readFileSync(file, "utf-8"); + try { + const sir = compile(src); + + if (options.generateSir) { + const outputFile = file.replace(".sia", ".json"); + writeFileSync(outputFile, JSON.stringify(sir, null, 2)); + console.info(`Sir file written to ${outputFile}`); + } + + if (options.extension) { + console.info(`Generating ${extension} file`); + } else { + console.info(`Detected extension: ${extension}`); + } + + const newFileName = file.replace(".sia", `.${extension}`); + const generatedSia = await generateSia(sir, extension); + writeFileSync(newFileName, generatedSia); + console.info(`Sia file written to ${newFileName}`); + } catch (error) { + logError(src, file, error as ILexingError | IRecognitionException); + process.exitCode = 1; + } + }); + +program.parse(); diff --git a/src/cli/javascript.ts b/src/cli/javascript.ts new file mode 100644 index 0000000..f6383c6 --- /dev/null +++ b/src/cli/javascript.ts @@ -0,0 +1,151 @@ +import { existsSync } from "fs"; +import path from "path"; +import * as prettier from "prettier"; +import { SchemaDefinition } from "../visitor.js"; +import { createLineBreakString } from "./common/index.js"; +import { + generateAttribute, + getRequiredSerializers, + getStringTypeFromLength, + isAnyString, +} from "./common/js/index.js"; +import { + siaTypeFunctionMap, + siaTypeSerializerArrayItemMap, +} from "./common/js/maps.js"; +import { + createCustomSerializerFunctionCallString, + createCustomSerializerFunctionDeclarationString, + createIfConditionString, + createNamedObjectString, + createSiaAddTypeFunctionCallString, + createSiaImportString, + createSiaInstanceString, + createSiaResultString, +} from "./common/js/strings.js"; +import { Generator, SiaType } from "./common/types.js"; + +export const isJsProject = () => { + return existsSync(path.join(process.cwd(), "package.json")); +}; + +export class JavaScriptGenerator implements Generator { + sir: SchemaDefinition[]; + + constructor(schemas: SchemaDefinition[]) { + this.sir = schemas; + } + + imports(): string { + const requiredSerializers = getRequiredSerializers(this.sir); + return createSiaImportString(["Sia", ...requiredSerializers]); + } + + types(): string { + return ""; + } + + sampleObject(): string { + const mainSchema = this.sir[0]; + const fields = mainSchema.fields + .map((field) => generateAttribute(field, this.sir)) + .join(createLineBreakString()); + + return createNamedObjectString(mainSchema.name.toLowerCase(), fields); + } + + siaInstance(): string { + const mainSchema = this.sir[0]; + const instanceName = `${mainSchema.name.toLowerCase()}Sia`; + let output = createSiaInstanceString(mainSchema.name); + output += createLineBreakString(); + + this.sir.forEach((schema) => { + output += this.generateSchemaFunction(schema); + output += createLineBreakString(2); + }); + + output += createCustomSerializerFunctionCallString( + mainSchema.name, + instanceName, + mainSchema.name.toLowerCase(), + ); + output += createLineBreakString(2); + output += createSiaResultString(instanceName); + + return output; + } + + private generateSchemaFunction(schema: SchemaDefinition): string { + let fnBody = ""; + + schema.fields.forEach((field) => { + let fieldType = field.type as SiaType; + const fieldName = `obj.${field.name}`; + + if (fieldType === SiaType.String) { + fieldType = getStringTypeFromLength(field.max); + } + + if (field.isArray) { + const serializer = + siaTypeSerializerArrayItemMap[ + fieldType as keyof typeof siaTypeSerializerArrayItemMap + ]; + fnBody += createSiaAddTypeFunctionCallString( + siaTypeFunctionMap[SiaType.Array8], + fieldName, + serializer, + ); + } else if (isAnyString(fieldType) && field.encoding === "ascii") { + fnBody += createSiaAddTypeFunctionCallString("addAscii", fieldName); + } else if (!Object.values(SiaType).includes(fieldType)) { + if (field.optional) { + fnBody += createIfConditionString( + fieldName, + createCustomSerializerFunctionCallString( + field.type, + "sia", + fieldName, + ), + ); + } else { + fnBody += createCustomSerializerFunctionCallString( + field.type, + "sia", + fieldName, + ); + } + } else { + const fn = siaTypeFunctionMap[fieldType]; + if (fn) { + fnBody += createSiaAddTypeFunctionCallString(fn, fieldName); + } + } + }); + + const fnName = `serialize${schema.name}`; + return createCustomSerializerFunctionDeclarationString( + fnName, + "sia, obj", + fnBody, + ); + } + + toString(): string { + const parts = [ + this.imports(), + "", + this.sampleObject(), + "", + this.siaInstance(), + ]; + + return parts.join("\n"); + } +} + +export const generateJs = async (schemas: SchemaDefinition[]) => { + const generator = new JavaScriptGenerator(schemas); + return prettier.format(generator.toString(), { parser: "babel" }); +}; diff --git a/src/utils/log.ts b/src/utils/log.ts index 620a1bf..d4fe26b 100644 --- a/src/utils/log.ts +++ b/src/utils/log.ts @@ -1,4 +1,4 @@ -import { IRecognitionException, ILexingError } from "chevrotain"; +import { ILexingError, IRecognitionException } from "chevrotain"; const getLines = (src: string, line: number) => src @@ -18,11 +18,11 @@ export const logLexerError = ( error: ILexingError, ) => { const code = addCaret(src, error.line as number, error.column as number); - console.log( + console.warn( `Lexing error in ${filename} at line ${error.line}:${error.column}\n`, ); - console.log(`${code}\n`); - console.log(error.message); + console.warn(`${code}\n`); + console.warn(error.message); }; export const logParserError = ( @@ -35,11 +35,11 @@ export const logParserError = ( error.token.startLine as number, error.token.endColumn as number, ); - console.log( + console.warn( `Parsing error in ${filename} at line ${error.token.startLine}:${error.token.startColumn}\n`, ); - console.log(`${code}\n`); - console.log(error.message); + console.warn(`${code}\n`); + console.warn(error.message); }; export const logError = ( diff --git a/src/visitor.ts b/src/visitor.ts index 68c0fd9..125edae 100644 --- a/src/visitor.ts +++ b/src/visitor.ts @@ -20,6 +20,8 @@ interface FieldDefinition { optional?: boolean; isArray?: boolean; defaultValue?: string | number | boolean; + min?: number; + max?: number; [key: string]: unknown; } diff --git a/yarn.lock b/yarn.lock index 9d046b5..bdf36bb 100644 --- a/yarn.lock +++ b/yarn.lock @@ -47,6 +47,174 @@ __metadata: languageName: node linkType: hard +"@esbuild/aix-ppc64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/aix-ppc64@npm:0.23.1" + conditions: os=aix & cpu=ppc64 + languageName: node + linkType: hard + +"@esbuild/android-arm64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/android-arm64@npm:0.23.1" + conditions: os=android & cpu=arm64 + languageName: node + linkType: hard + +"@esbuild/android-arm@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/android-arm@npm:0.23.1" + conditions: os=android & cpu=arm + languageName: node + linkType: hard + +"@esbuild/android-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/android-x64@npm:0.23.1" + conditions: os=android & cpu=x64 + languageName: node + linkType: hard + +"@esbuild/darwin-arm64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/darwin-arm64@npm:0.23.1" + conditions: os=darwin & cpu=arm64 + languageName: node + linkType: hard + +"@esbuild/darwin-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/darwin-x64@npm:0.23.1" + conditions: os=darwin & cpu=x64 + languageName: node + linkType: hard + +"@esbuild/freebsd-arm64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/freebsd-arm64@npm:0.23.1" + conditions: os=freebsd & cpu=arm64 + languageName: node + linkType: hard + +"@esbuild/freebsd-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/freebsd-x64@npm:0.23.1" + conditions: os=freebsd & cpu=x64 + languageName: node + linkType: hard + +"@esbuild/linux-arm64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-arm64@npm:0.23.1" + conditions: os=linux & cpu=arm64 + languageName: node + linkType: hard + +"@esbuild/linux-arm@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-arm@npm:0.23.1" + conditions: os=linux & cpu=arm + languageName: node + linkType: hard + +"@esbuild/linux-ia32@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-ia32@npm:0.23.1" + conditions: os=linux & cpu=ia32 + languageName: node + linkType: hard + +"@esbuild/linux-loong64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-loong64@npm:0.23.1" + conditions: os=linux & cpu=loong64 + languageName: node + linkType: hard + +"@esbuild/linux-mips64el@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-mips64el@npm:0.23.1" + conditions: os=linux & cpu=mips64el + languageName: node + linkType: hard + +"@esbuild/linux-ppc64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-ppc64@npm:0.23.1" + conditions: os=linux & cpu=ppc64 + languageName: node + linkType: hard + +"@esbuild/linux-riscv64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-riscv64@npm:0.23.1" + conditions: os=linux & cpu=riscv64 + languageName: node + linkType: hard + +"@esbuild/linux-s390x@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-s390x@npm:0.23.1" + conditions: os=linux & cpu=s390x + languageName: node + linkType: hard + +"@esbuild/linux-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/linux-x64@npm:0.23.1" + conditions: os=linux & cpu=x64 + languageName: node + linkType: hard + +"@esbuild/netbsd-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/netbsd-x64@npm:0.23.1" + conditions: os=netbsd & cpu=x64 + languageName: node + linkType: hard + +"@esbuild/openbsd-arm64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/openbsd-arm64@npm:0.23.1" + conditions: os=openbsd & cpu=arm64 + languageName: node + linkType: hard + +"@esbuild/openbsd-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/openbsd-x64@npm:0.23.1" + conditions: os=openbsd & cpu=x64 + languageName: node + linkType: hard + +"@esbuild/sunos-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/sunos-x64@npm:0.23.1" + conditions: os=sunos & cpu=x64 + languageName: node + linkType: hard + +"@esbuild/win32-arm64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/win32-arm64@npm:0.23.1" + conditions: os=win32 & cpu=arm64 + languageName: node + linkType: hard + +"@esbuild/win32-ia32@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/win32-ia32@npm:0.23.1" + conditions: os=win32 & cpu=ia32 + languageName: node + linkType: hard + +"@esbuild/win32-x64@npm:0.23.1": + version: 0.23.1 + resolution: "@esbuild/win32-x64@npm:0.23.1" + conditions: os=win32 & cpu=x64 + languageName: node + linkType: hard + "@eslint-community/eslint-utils@npm:^4.2.0, @eslint-community/eslint-utils@npm:^4.4.0": version: 4.4.1 resolution: "@eslint-community/eslint-utils@npm:4.4.1" @@ -161,6 +329,29 @@ __metadata: languageName: node linkType: hard +"@isaacs/cliui@npm:^8.0.2": + version: 8.0.2 + resolution: "@isaacs/cliui@npm:8.0.2" + dependencies: + string-width: "npm:^5.1.2" + string-width-cjs: "npm:string-width@^4.2.0" + strip-ansi: "npm:^7.0.1" + strip-ansi-cjs: "npm:strip-ansi@^6.0.1" + wrap-ansi: "npm:^8.1.0" + wrap-ansi-cjs: "npm:wrap-ansi@^7.0.0" + checksum: 10c0/b1bf42535d49f11dc137f18d5e4e63a28c5569de438a221c369483731e9dac9fb797af554e8bf02b6192d1e5eba6e6402cf93900c3d0ac86391d00d04876789e + languageName: node + linkType: hard + +"@isaacs/fs-minipass@npm:^4.0.0": + version: 4.0.1 + resolution: "@isaacs/fs-minipass@npm:4.0.1" + dependencies: + minipass: "npm:^7.0.4" + checksum: 10c0/c25b6dc1598790d5b55c0947a9b7d111cfa92594db5296c3b907e2f533c033666f692a3939eadac17b1c7c40d362d0b0635dc874cbfe3e70db7c2b07cc97a5d2 + languageName: node + linkType: hard + "@nodelib/fs.scandir@npm:2.1.5": version: 2.1.5 resolution: "@nodelib/fs.scandir@npm:2.1.5" @@ -188,6 +379,35 @@ __metadata: languageName: node linkType: hard +"@npmcli/agent@npm:^3.0.0": + version: 3.0.0 + resolution: "@npmcli/agent@npm:3.0.0" + dependencies: + agent-base: "npm:^7.1.0" + http-proxy-agent: "npm:^7.0.0" + https-proxy-agent: "npm:^7.0.1" + lru-cache: "npm:^10.0.1" + socks-proxy-agent: "npm:^8.0.3" + checksum: 10c0/efe37b982f30740ee77696a80c196912c274ecd2cb243bc6ae7053a50c733ce0f6c09fda085145f33ecf453be19654acca74b69e81eaad4c90f00ccffe2f9271 + languageName: node + linkType: hard + +"@npmcli/fs@npm:^4.0.0": + version: 4.0.0 + resolution: "@npmcli/fs@npm:4.0.0" + dependencies: + semver: "npm:^7.3.5" + checksum: 10c0/c90935d5ce670c87b6b14fab04a965a3b8137e585f8b2a6257263bd7f97756dd736cb165bb470e5156a9e718ecd99413dccc54b1138c1a46d6ec7cf325982fe5 + languageName: node + linkType: hard + +"@pkgjs/parseargs@npm:^0.11.0": + version: 0.11.0 + resolution: "@pkgjs/parseargs@npm:0.11.0" + checksum: 10c0/5bd7576bb1b38a47a7fc7b51ac9f38748e772beebc56200450c4a817d712232b8f1d3ef70532c80840243c657d491cf6a6be1e3a214cff907645819fdc34aadd + languageName: node + linkType: hard + "@pkgr/core@npm:^0.1.0": version: 0.1.1 resolution: "@pkgr/core@npm:0.1.1" @@ -339,6 +559,13 @@ __metadata: languageName: node linkType: hard +"abbrev@npm:^2.0.0": + version: 2.0.0 + resolution: "abbrev@npm:2.0.0" + checksum: 10c0/f742a5a107473946f426c691c08daba61a1d15942616f300b5d32fd735be88fef5cba24201757b6c407fd564555fb48c751cfa33519b2605c8a7aadd22baf372 + languageName: node + linkType: hard + "acorn-jsx@npm:^5.3.2": version: 5.3.2 resolution: "acorn-jsx@npm:5.3.2" @@ -357,6 +584,15 @@ __metadata: languageName: node linkType: hard +"agent-base@npm:^7.0.2, agent-base@npm:^7.1.0, agent-base@npm:^7.1.1": + version: 7.1.1 + resolution: "agent-base@npm:7.1.1" + dependencies: + debug: "npm:^4.3.4" + checksum: 10c0/e59ce7bed9c63bf071a30cc471f2933862044c97fd9958967bfe22521d7a0f601ce4ed5a8c011799d0c726ca70312142ae193bbebb60f576b52be19d4a363b50 + languageName: node + linkType: hard + "ajv@npm:^6.12.4": version: 6.12.6 resolution: "ajv@npm:6.12.6" @@ -369,7 +605,21 @@ __metadata: languageName: node linkType: hard -"ansi-styles@npm:^4.1.0": +"ansi-regex@npm:^5.0.1": + version: 5.0.1 + resolution: "ansi-regex@npm:5.0.1" + checksum: 10c0/9a64bb8627b434ba9327b60c027742e5d17ac69277960d041898596271d992d4d52ba7267a63ca10232e29f6107fc8a835f6ce8d719b88c5f8493f8254813737 + languageName: node + linkType: hard + +"ansi-regex@npm:^6.0.1": + version: 6.1.0 + resolution: "ansi-regex@npm:6.1.0" + checksum: 10c0/a91daeddd54746338478eef88af3439a7edf30f8e23196e2d6ed182da9add559c601266dbef01c2efa46a958ad6f1f8b176799657616c702b5b02e799e7fd8dc + languageName: node + linkType: hard + +"ansi-styles@npm:^4.0.0, ansi-styles@npm:^4.1.0": version: 4.3.0 resolution: "ansi-styles@npm:4.3.0" dependencies: @@ -378,6 +628,13 @@ __metadata: languageName: node linkType: hard +"ansi-styles@npm:^6.1.0": + version: 6.2.1 + resolution: "ansi-styles@npm:6.2.1" + checksum: 10c0/5d1ec38c123984bcedd996eac680d548f31828bd679a66db2bdf11844634dde55fec3efa9c6bb1d89056a5e79c1ac540c4c784d592ea1d25028a92227d2f2d5c + languageName: node + linkType: hard + "argparse@npm:^2.0.1": version: 2.0.1 resolution: "argparse@npm:2.0.1" @@ -420,6 +677,26 @@ __metadata: languageName: node linkType: hard +"cacache@npm:^19.0.1": + version: 19.0.1 + resolution: "cacache@npm:19.0.1" + dependencies: + "@npmcli/fs": "npm:^4.0.0" + fs-minipass: "npm:^3.0.0" + glob: "npm:^10.2.2" + lru-cache: "npm:^10.0.1" + minipass: "npm:^7.0.3" + minipass-collect: "npm:^2.0.1" + minipass-flush: "npm:^1.0.5" + minipass-pipeline: "npm:^1.2.4" + p-map: "npm:^7.0.2" + ssri: "npm:^12.0.0" + tar: "npm:^7.4.3" + unique-filename: "npm:^4.0.0" + checksum: 10c0/01f2134e1bd7d3ab68be851df96c8d63b492b1853b67f2eecb2c37bb682d37cb70bb858a16f2f0554d3c0071be6dfe21456a1ff6fa4b7eed996570d6a25ffe9c + languageName: node + linkType: hard + "callsites@npm:^3.0.0": version: 3.1.0 resolution: "callsites@npm:3.1.0" @@ -451,6 +728,13 @@ __metadata: languageName: node linkType: hard +"chownr@npm:^3.0.0": + version: 3.0.0 + resolution: "chownr@npm:3.0.0" + checksum: 10c0/43925b87700f7e3893296c8e9c56cc58f926411cce3a6e5898136daaf08f08b9a8eb76d37d3267e707d0dcc17aed2e2ebdf5848c0c3ce95cf910a919935c1b10 + languageName: node + linkType: hard + "color-convert@npm:^2.0.1": version: 2.0.1 resolution: "color-convert@npm:2.0.1" @@ -481,7 +765,7 @@ __metadata: languageName: node linkType: hard -"cross-spawn@npm:^7.0.5": +"cross-spawn@npm:^7.0.0, cross-spawn@npm:^7.0.5": version: 7.0.6 resolution: "cross-spawn@npm:7.0.6" dependencies: @@ -492,7 +776,7 @@ __metadata: languageName: node linkType: hard -"debug@npm:^4.3.1, debug@npm:^4.3.2, debug@npm:^4.3.4": +"debug@npm:4, debug@npm:^4.3.1, debug@npm:^4.3.2, debug@npm:^4.3.4": version: 4.3.7 resolution: "debug@npm:4.3.7" dependencies: @@ -511,6 +795,133 @@ __metadata: languageName: node linkType: hard +"eastasianwidth@npm:^0.2.0": + version: 0.2.0 + resolution: "eastasianwidth@npm:0.2.0" + checksum: 10c0/26f364ebcdb6395f95124fda411f63137a4bfb5d3a06453f7f23dfe52502905bd84e0488172e0f9ec295fdc45f05c23d5d91baf16bd26f0fe9acd777a188dc39 + languageName: node + linkType: hard + +"emoji-regex@npm:^8.0.0": + version: 8.0.0 + resolution: "emoji-regex@npm:8.0.0" + checksum: 10c0/b6053ad39951c4cf338f9092d7bfba448cdfd46fe6a2a034700b149ac9ffbc137e361cbd3c442297f86bed2e5f7576c1b54cc0a6bf8ef5106cc62f496af35010 + languageName: node + linkType: hard + +"emoji-regex@npm:^9.2.2": + version: 9.2.2 + resolution: "emoji-regex@npm:9.2.2" + checksum: 10c0/af014e759a72064cf66e6e694a7fc6b0ed3d8db680427b021a89727689671cefe9d04151b2cad51dbaf85d5ba790d061cd167f1cf32eb7b281f6368b3c181639 + languageName: node + linkType: hard + +"encoding@npm:^0.1.13": + version: 0.1.13 + resolution: "encoding@npm:0.1.13" + dependencies: + iconv-lite: "npm:^0.6.2" + checksum: 10c0/36d938712ff00fe1f4bac88b43bcffb5930c1efa57bbcdca9d67e1d9d6c57cfb1200fb01efe0f3109b2ce99b231f90779532814a81370a1bd3274a0f58585039 + languageName: node + linkType: hard + +"env-paths@npm:^2.2.0": + version: 2.2.1 + resolution: "env-paths@npm:2.2.1" + checksum: 10c0/285325677bf00e30845e330eec32894f5105529db97496ee3f598478e50f008c5352a41a30e5e72ec9de8a542b5a570b85699cd63bd2bc646dbcb9f311d83bc4 + languageName: node + linkType: hard + +"err-code@npm:^2.0.2": + version: 2.0.3 + resolution: "err-code@npm:2.0.3" + checksum: 10c0/b642f7b4dd4a376e954947550a3065a9ece6733ab8e51ad80db727aaae0817c2e99b02a97a3d6cecc648a97848305e728289cf312d09af395403a90c9d4d8a66 + languageName: node + linkType: hard + +"esbuild@npm:~0.23.0": + version: 0.23.1 + resolution: "esbuild@npm:0.23.1" + dependencies: + "@esbuild/aix-ppc64": "npm:0.23.1" + "@esbuild/android-arm": "npm:0.23.1" + "@esbuild/android-arm64": "npm:0.23.1" + "@esbuild/android-x64": "npm:0.23.1" + "@esbuild/darwin-arm64": "npm:0.23.1" + "@esbuild/darwin-x64": "npm:0.23.1" + "@esbuild/freebsd-arm64": "npm:0.23.1" + "@esbuild/freebsd-x64": "npm:0.23.1" + "@esbuild/linux-arm": "npm:0.23.1" + "@esbuild/linux-arm64": "npm:0.23.1" + "@esbuild/linux-ia32": "npm:0.23.1" + "@esbuild/linux-loong64": "npm:0.23.1" + "@esbuild/linux-mips64el": "npm:0.23.1" + "@esbuild/linux-ppc64": "npm:0.23.1" + "@esbuild/linux-riscv64": "npm:0.23.1" + "@esbuild/linux-s390x": "npm:0.23.1" + "@esbuild/linux-x64": "npm:0.23.1" + "@esbuild/netbsd-x64": "npm:0.23.1" + "@esbuild/openbsd-arm64": "npm:0.23.1" + "@esbuild/openbsd-x64": "npm:0.23.1" + "@esbuild/sunos-x64": "npm:0.23.1" + "@esbuild/win32-arm64": "npm:0.23.1" + "@esbuild/win32-ia32": "npm:0.23.1" + "@esbuild/win32-x64": "npm:0.23.1" + dependenciesMeta: + "@esbuild/aix-ppc64": + optional: true + "@esbuild/android-arm": + optional: true + "@esbuild/android-arm64": + optional: true + "@esbuild/android-x64": + optional: true + "@esbuild/darwin-arm64": + optional: true + "@esbuild/darwin-x64": + optional: true + "@esbuild/freebsd-arm64": + optional: true + "@esbuild/freebsd-x64": + optional: true + "@esbuild/linux-arm": + optional: true + "@esbuild/linux-arm64": + optional: true + "@esbuild/linux-ia32": + optional: true + "@esbuild/linux-loong64": + optional: true + "@esbuild/linux-mips64el": + optional: true + "@esbuild/linux-ppc64": + optional: true + "@esbuild/linux-riscv64": + optional: true + "@esbuild/linux-s390x": + optional: true + "@esbuild/linux-x64": + optional: true + "@esbuild/netbsd-x64": + optional: true + "@esbuild/openbsd-arm64": + optional: true + "@esbuild/openbsd-x64": + optional: true + "@esbuild/sunos-x64": + optional: true + "@esbuild/win32-arm64": + optional: true + "@esbuild/win32-ia32": + optional: true + "@esbuild/win32-x64": + optional: true + bin: + esbuild: bin/esbuild + checksum: 10c0/08c2ed1105cc3c5e3a24a771e35532fe6089dd24a39c10097899072cef4a99f20860e41e9294e000d86380f353b04d8c50af482483d7f69f5208481cce61eec7 + languageName: node + linkType: hard + "escape-string-regexp@npm:^4.0.0": version: 4.0.0 resolution: "escape-string-regexp@npm:4.0.0" @@ -665,6 +1076,13 @@ __metadata: languageName: node linkType: hard +"exponential-backoff@npm:^3.1.1": + version: 3.1.1 + resolution: "exponential-backoff@npm:3.1.1" + checksum: 10c0/160456d2d647e6019640bd07111634d8c353038d9fa40176afb7cd49b0548bdae83b56d05e907c2cce2300b81cae35d800ef92fefb9d0208e190fa3b7d6bb579 + languageName: node + linkType: hard + "fast-deep-equal@npm:^3.1.1, fast-deep-equal@npm:^3.1.3": version: 3.1.3 resolution: "fast-deep-equal@npm:3.1.3" @@ -760,6 +1178,53 @@ __metadata: languageName: node linkType: hard +"foreground-child@npm:^3.1.0": + version: 3.3.0 + resolution: "foreground-child@npm:3.3.0" + dependencies: + cross-spawn: "npm:^7.0.0" + signal-exit: "npm:^4.0.1" + checksum: 10c0/028f1d41000553fcfa6c4bb5c372963bf3d9bf0b1f25a87d1a6253014343fb69dfb1b42d9625d7cf44c8ba429940f3d0ff718b62105d4d4a4f6ef8ca0a53faa2 + languageName: node + linkType: hard + +"fs-minipass@npm:^3.0.0": + version: 3.0.3 + resolution: "fs-minipass@npm:3.0.3" + dependencies: + minipass: "npm:^7.0.3" + checksum: 10c0/63e80da2ff9b621e2cb1596abcb9207f1cf82b968b116ccd7b959e3323144cce7fb141462200971c38bbf2ecca51695069db45265705bed09a7cd93ae5b89f94 + languageName: node + linkType: hard + +"fsevents@npm:~2.3.3": + version: 2.3.3 + resolution: "fsevents@npm:2.3.3" + dependencies: + node-gyp: "npm:latest" + checksum: 10c0/a1f0c44595123ed717febbc478aa952e47adfc28e2092be66b8ab1635147254ca6cfe1df792a8997f22716d4cbafc73309899ff7bfac2ac3ad8cf2e4ecc3ec60 + conditions: os=darwin + languageName: node + linkType: hard + +"fsevents@patch:fsevents@npm%3A~2.3.3#optional!builtin": + version: 2.3.3 + resolution: "fsevents@patch:fsevents@npm%3A2.3.3#optional!builtin::version=2.3.3&hash=df0bf1" + dependencies: + node-gyp: "npm:latest" + conditions: os=darwin + languageName: node + linkType: hard + +"get-tsconfig@npm:^4.7.5": + version: 4.8.1 + resolution: "get-tsconfig@npm:4.8.1" + dependencies: + resolve-pkg-maps: "npm:^1.0.0" + checksum: 10c0/536ee85d202f604f4b5fb6be81bcd6e6d9a96846811e83e9acc6de4a04fb49506edea0e1b8cf1d5ee7af33e469916ec2809d4c5445ab8ae015a7a51fbd1572f9 + languageName: node + linkType: hard + "glob-parent@npm:^5.1.2": version: 5.1.2 resolution: "glob-parent@npm:5.1.2" @@ -778,6 +1243,22 @@ __metadata: languageName: node linkType: hard +"glob@npm:^10.2.2, glob@npm:^10.3.10, glob@npm:^10.3.7": + version: 10.4.5 + resolution: "glob@npm:10.4.5" + dependencies: + foreground-child: "npm:^3.1.0" + jackspeak: "npm:^3.1.2" + minimatch: "npm:^9.0.4" + minipass: "npm:^7.1.2" + package-json-from-dist: "npm:^1.0.0" + path-scurry: "npm:^1.11.1" + bin: + glob: dist/esm/bin.mjs + checksum: 10c0/19a9759ea77b8e3ca0a43c2f07ecddc2ad46216b786bb8f993c445aee80d345925a21e5280c7b7c6c59e860a0154b84e4b2b60321fea92cd3c56b4a7489f160e + languageName: node + linkType: hard + "globals@npm:^14.0.0": version: 14.0.0 resolution: "globals@npm:14.0.0" @@ -792,6 +1273,13 @@ __metadata: languageName: node linkType: hard +"graceful-fs@npm:^4.2.6": + version: 4.2.11 + resolution: "graceful-fs@npm:4.2.11" + checksum: 10c0/386d011a553e02bc594ac2ca0bd6d9e4c22d7fa8cfbfc448a6d148c59ea881b092db9dbe3547ae4b88e55f1b01f7c4a2ecc53b310c042793e63aa44cf6c257f2 + languageName: node + linkType: hard + "graphemer@npm:^1.4.0": version: 1.4.0 resolution: "graphemer@npm:1.4.0" @@ -806,6 +1294,42 @@ __metadata: languageName: node linkType: hard +"http-cache-semantics@npm:^4.1.1": + version: 4.1.1 + resolution: "http-cache-semantics@npm:4.1.1" + checksum: 10c0/ce1319b8a382eb3cbb4a37c19f6bfe14e5bb5be3d09079e885e8c513ab2d3cd9214902f8a31c9dc4e37022633ceabfc2d697405deeaf1b8f3552bb4ed996fdfc + languageName: node + linkType: hard + +"http-proxy-agent@npm:^7.0.0": + version: 7.0.2 + resolution: "http-proxy-agent@npm:7.0.2" + dependencies: + agent-base: "npm:^7.1.0" + debug: "npm:^4.3.4" + checksum: 10c0/4207b06a4580fb85dd6dff521f0abf6db517489e70863dca1a0291daa7f2d3d2d6015a57bd702af068ea5cf9f1f6ff72314f5f5b4228d299c0904135d2aef921 + languageName: node + linkType: hard + +"https-proxy-agent@npm:^7.0.1": + version: 7.0.5 + resolution: "https-proxy-agent@npm:7.0.5" + dependencies: + agent-base: "npm:^7.0.2" + debug: "npm:4" + checksum: 10c0/2490e3acec397abeb88807db52cac59102d5ed758feee6df6112ab3ccd8325e8a1ce8bce6f4b66e5470eca102d31e425ace904242e4fa28dbe0c59c4bafa7b2c + languageName: node + linkType: hard + +"iconv-lite@npm:^0.6.2": + version: 0.6.3 + resolution: "iconv-lite@npm:0.6.3" + dependencies: + safer-buffer: "npm:>= 2.1.2 < 3.0.0" + checksum: 10c0/98102bc66b33fcf5ac044099d1257ba0b7ad5e3ccd3221f34dd508ab4070edff183276221684e1e0555b145fce0850c9f7d2b60a9fcac50fbb4ea0d6e845a3b1 + languageName: node + linkType: hard + "ignore@npm:^5.2.0, ignore@npm:^5.3.1": version: 5.3.2 resolution: "ignore@npm:5.3.2" @@ -830,6 +1354,16 @@ __metadata: languageName: node linkType: hard +"ip-address@npm:^9.0.5": + version: 9.0.5 + resolution: "ip-address@npm:9.0.5" + dependencies: + jsbn: "npm:1.1.0" + sprintf-js: "npm:^1.1.3" + checksum: 10c0/331cd07fafcb3b24100613e4b53e1a2b4feab11e671e655d46dc09ee233da5011284d09ca40c4ecbdfe1d0004f462958675c224a804259f2f78d2465a87824bc + languageName: node + linkType: hard + "is-extglob@npm:^2.1.1": version: 2.1.1 resolution: "is-extglob@npm:2.1.1" @@ -837,6 +1371,13 @@ __metadata: languageName: node linkType: hard +"is-fullwidth-code-point@npm:^3.0.0": + version: 3.0.0 + resolution: "is-fullwidth-code-point@npm:3.0.0" + checksum: 10c0/bb11d825e049f38e04c06373a8d72782eee0205bda9d908cc550ccb3c59b99d750ff9537982e01733c1c94a58e35400661f57042158ff5e8f3e90cf936daf0fc + languageName: node + linkType: hard + "is-glob@npm:^4.0.0, is-glob@npm:^4.0.1, is-glob@npm:^4.0.3": version: 4.0.3 resolution: "is-glob@npm:4.0.3" @@ -860,6 +1401,26 @@ __metadata: languageName: node linkType: hard +"isexe@npm:^3.1.1": + version: 3.1.1 + resolution: "isexe@npm:3.1.1" + checksum: 10c0/9ec257654093443eb0a528a9c8cbba9c0ca7616ccb40abd6dde7202734d96bb86e4ac0d764f0f8cd965856aacbff2f4ce23e730dc19dfb41e3b0d865ca6fdcc7 + languageName: node + linkType: hard + +"jackspeak@npm:^3.1.2": + version: 3.4.3 + resolution: "jackspeak@npm:3.4.3" + dependencies: + "@isaacs/cliui": "npm:^8.0.2" + "@pkgjs/parseargs": "npm:^0.11.0" + dependenciesMeta: + "@pkgjs/parseargs": + optional: true + checksum: 10c0/6acc10d139eaefdbe04d2f679e6191b3abf073f111edf10b1de5302c97ec93fffeb2fdd8681ed17f16268aa9dd4f8c588ed9d1d3bffbbfa6e8bf897cbb3149b9 + languageName: node + linkType: hard + "js-yaml@npm:^4.1.0": version: 4.1.0 resolution: "js-yaml@npm:4.1.0" @@ -871,6 +1432,13 @@ __metadata: languageName: node linkType: hard +"jsbn@npm:1.1.0": + version: 1.1.0 + resolution: "jsbn@npm:1.1.0" + checksum: 10c0/4f907fb78d7b712e11dea8c165fe0921f81a657d3443dde75359ed52eb2b5d33ce6773d97985a089f09a65edd80b11cb75c767b57ba47391fee4c969f7215c96 + languageName: node + linkType: hard + "json-buffer@npm:3.0.1": version: 3.0.1 resolution: "json-buffer@npm:3.0.1" @@ -934,6 +1502,32 @@ __metadata: languageName: node linkType: hard +"lru-cache@npm:^10.0.1, lru-cache@npm:^10.2.0": + version: 10.4.3 + resolution: "lru-cache@npm:10.4.3" + checksum: 10c0/ebd04fbca961e6c1d6c0af3799adcc966a1babe798f685bb84e6599266599cd95d94630b10262f5424539bc4640107e8a33aa28585374abf561d30d16f4b39fb + languageName: node + linkType: hard + +"make-fetch-happen@npm:^14.0.3": + version: 14.0.3 + resolution: "make-fetch-happen@npm:14.0.3" + dependencies: + "@npmcli/agent": "npm:^3.0.0" + cacache: "npm:^19.0.1" + http-cache-semantics: "npm:^4.1.1" + minipass: "npm:^7.0.2" + minipass-fetch: "npm:^4.0.0" + minipass-flush: "npm:^1.0.5" + minipass-pipeline: "npm:^1.2.4" + negotiator: "npm:^1.0.0" + proc-log: "npm:^5.0.0" + promise-retry: "npm:^2.0.1" + ssri: "npm:^12.0.0" + checksum: 10c0/c40efb5e5296e7feb8e37155bde8eb70bc57d731b1f7d90e35a092fde403d7697c56fb49334d92d330d6f1ca29a98142036d6480a12681133a0a1453164cb2f0 + languageName: node + linkType: hard + "merge2@npm:^1.3.0": version: 1.4.1 resolution: "merge2@npm:1.4.1" @@ -969,6 +1563,92 @@ __metadata: languageName: node linkType: hard +"minipass-collect@npm:^2.0.1": + version: 2.0.1 + resolution: "minipass-collect@npm:2.0.1" + dependencies: + minipass: "npm:^7.0.3" + checksum: 10c0/5167e73f62bb74cc5019594709c77e6a742051a647fe9499abf03c71dca75515b7959d67a764bdc4f8b361cf897fbf25e2d9869ee039203ed45240f48b9aa06e + languageName: node + linkType: hard + +"minipass-fetch@npm:^4.0.0": + version: 4.0.0 + resolution: "minipass-fetch@npm:4.0.0" + dependencies: + encoding: "npm:^0.1.13" + minipass: "npm:^7.0.3" + minipass-sized: "npm:^1.0.3" + minizlib: "npm:^3.0.1" + dependenciesMeta: + encoding: + optional: true + checksum: 10c0/7fa30ce7c373fb6f94c086b374fff1589fd7e78451855d2d06c2e2d9df936d131e73e952163063016592ed3081444bd8d1ea608533313b0149156ce23311da4b + languageName: node + linkType: hard + +"minipass-flush@npm:^1.0.5": + version: 1.0.5 + resolution: "minipass-flush@npm:1.0.5" + dependencies: + minipass: "npm:^3.0.0" + checksum: 10c0/2a51b63feb799d2bb34669205eee7c0eaf9dce01883261a5b77410c9408aa447e478efd191b4de6fc1101e796ff5892f8443ef20d9544385819093dbb32d36bd + languageName: node + linkType: hard + +"minipass-pipeline@npm:^1.2.4": + version: 1.2.4 + resolution: "minipass-pipeline@npm:1.2.4" + dependencies: + minipass: "npm:^3.0.0" + checksum: 10c0/cbda57cea20b140b797505dc2cac71581a70b3247b84480c1fed5ca5ba46c25ecc25f68bfc9e6dcb1a6e9017dab5c7ada5eab73ad4f0a49d84e35093e0c643f2 + languageName: node + linkType: hard + +"minipass-sized@npm:^1.0.3": + version: 1.0.3 + resolution: "minipass-sized@npm:1.0.3" + dependencies: + minipass: "npm:^3.0.0" + checksum: 10c0/298f124753efdc745cfe0f2bdfdd81ba25b9f4e753ca4a2066eb17c821f25d48acea607dfc997633ee5bf7b6dfffb4eee4f2051eb168663f0b99fad2fa4829cb + languageName: node + linkType: hard + +"minipass@npm:^3.0.0": + version: 3.3.6 + resolution: "minipass@npm:3.3.6" + dependencies: + yallist: "npm:^4.0.0" + checksum: 10c0/a114746943afa1dbbca8249e706d1d38b85ed1298b530f5808ce51f8e9e941962e2a5ad2e00eae7dd21d8a4aae6586a66d4216d1a259385e9d0358f0c1eba16c + languageName: node + linkType: hard + +"minipass@npm:^5.0.0 || ^6.0.2 || ^7.0.0, minipass@npm:^7.0.2, minipass@npm:^7.0.3, minipass@npm:^7.0.4, minipass@npm:^7.1.2": + version: 7.1.2 + resolution: "minipass@npm:7.1.2" + checksum: 10c0/b0fd20bb9fb56e5fa9a8bfac539e8915ae07430a619e4b86ff71f5fc757ef3924b23b2c4230393af1eda647ed3d75739e4e0acb250a6b1eb277cf7f8fe449557 + languageName: node + linkType: hard + +"minizlib@npm:^3.0.1": + version: 3.0.1 + resolution: "minizlib@npm:3.0.1" + dependencies: + minipass: "npm:^7.0.4" + rimraf: "npm:^5.0.5" + checksum: 10c0/82f8bf70da8af656909a8ee299d7ed3b3372636749d29e105f97f20e88971be31f5ed7642f2e898f00283b68b701cc01307401cdc209b0efc5dd3818220e5093 + languageName: node + linkType: hard + +"mkdirp@npm:^3.0.1": + version: 3.0.1 + resolution: "mkdirp@npm:3.0.1" + bin: + mkdirp: dist/cjs/src/bin.js + checksum: 10c0/9f2b975e9246351f5e3a40dcfac99fcd0baa31fbfab615fe059fb11e51f10e4803c63de1f384c54d656e4db31d000e4767e9ef076a22e12a641357602e31d57d + languageName: node + linkType: hard + "ms@npm:^2.1.3": version: 2.1.3 resolution: "ms@npm:2.1.3" @@ -983,6 +1663,44 @@ __metadata: languageName: node linkType: hard +"negotiator@npm:^1.0.0": + version: 1.0.0 + resolution: "negotiator@npm:1.0.0" + checksum: 10c0/4c559dd52669ea48e1914f9d634227c561221dd54734070791f999c52ed0ff36e437b2e07d5c1f6e32909fc625fe46491c16e4a8f0572567d4dd15c3a4fda04b + languageName: node + linkType: hard + +"node-gyp@npm:latest": + version: 11.0.0 + resolution: "node-gyp@npm:11.0.0" + dependencies: + env-paths: "npm:^2.2.0" + exponential-backoff: "npm:^3.1.1" + glob: "npm:^10.3.10" + graceful-fs: "npm:^4.2.6" + make-fetch-happen: "npm:^14.0.3" + nopt: "npm:^8.0.0" + proc-log: "npm:^5.0.0" + semver: "npm:^7.3.5" + tar: "npm:^7.4.3" + which: "npm:^5.0.0" + bin: + node-gyp: bin/node-gyp.js + checksum: 10c0/a3b885bbee2d271f1def32ba2e30ffcf4562a3db33af06b8b365e053153e2dd2051b9945783c3c8e852d26a0f20f65b251c7e83361623383a99635c0280ee573 + languageName: node + linkType: hard + +"nopt@npm:^8.0.0": + version: 8.0.0 + resolution: "nopt@npm:8.0.0" + dependencies: + abbrev: "npm:^2.0.0" + bin: + nopt: bin/nopt.js + checksum: 10c0/19cb986f79abaca2d0f0b560021da7b32ee6fcc3de48f3eaeb0c324d36755c17754f886a754c091f01f740c17caf7d6aea8237b7fbaf39f476ae5e30a249f18f + languageName: node + linkType: hard + "optionator@npm:^0.9.3": version: 0.9.4 resolution: "optionator@npm:0.9.4" @@ -1015,6 +1733,20 @@ __metadata: languageName: node linkType: hard +"p-map@npm:^7.0.2": + version: 7.0.3 + resolution: "p-map@npm:7.0.3" + checksum: 10c0/46091610da2b38ce47bcd1d8b4835a6fa4e832848a6682cf1652bc93915770f4617afc844c10a77d1b3e56d2472bb2d5622353fa3ead01a7f42b04fc8e744a5c + languageName: node + linkType: hard + +"package-json-from-dist@npm:^1.0.0": + version: 1.0.1 + resolution: "package-json-from-dist@npm:1.0.1" + checksum: 10c0/62ba2785eb655fec084a257af34dbe24292ab74516d6aecef97ef72d4897310bc6898f6c85b5cd22770eaa1ce60d55a0230e150fb6a966e3ecd6c511e23d164b + languageName: node + linkType: hard + "parent-module@npm:^1.0.0": version: 1.0.1 resolution: "parent-module@npm:1.0.1" @@ -1038,6 +1770,16 @@ __metadata: languageName: node linkType: hard +"path-scurry@npm:^1.11.1": + version: 1.11.1 + resolution: "path-scurry@npm:1.11.1" + dependencies: + lru-cache: "npm:^10.2.0" + minipass: "npm:^5.0.0 || ^6.0.2 || ^7.0.0" + checksum: 10c0/32a13711a2a505616ae1cc1b5076801e453e7aae6ac40ab55b388bb91b9d0547a52f5aaceff710ea400205f18691120d4431e520afbe4266b836fadede15872d + languageName: node + linkType: hard + "picomatch@npm:^2.3.1": version: 2.3.1 resolution: "picomatch@npm:2.3.1" @@ -1061,12 +1803,29 @@ __metadata: languageName: node linkType: hard -"prettier@npm:^3.4.1": - version: 3.4.1 - resolution: "prettier@npm:3.4.1" +"prettier@npm:^3.4.2": + version: 3.4.2 + resolution: "prettier@npm:3.4.2" bin: prettier: bin/prettier.cjs - checksum: 10c0/2d6cc3101ad9de72b49c59339480b0983e6ff6742143da0c43f476bf3b5ef88ede42ebd9956d7a0a8fa59f7a5990e8ef03c9ad4c37f7e4c9e5db43ee0853156c + checksum: 10c0/99e076a26ed0aba4ebc043880d0f08bbb8c59a4c6641cdee6cdadf2205bdd87aa1d7823f50c3aea41e015e99878d37c58d7b5f0e663bba0ef047f94e36b96446 + languageName: node + linkType: hard + +"proc-log@npm:^5.0.0": + version: 5.0.0 + resolution: "proc-log@npm:5.0.0" + checksum: 10c0/bbe5edb944b0ad63387a1d5b1911ae93e05ce8d0f60de1035b218cdcceedfe39dbd2c697853355b70f1a090f8f58fe90da487c85216bf9671f9499d1a897e9e3 + languageName: node + linkType: hard + +"promise-retry@npm:^2.0.1": + version: 2.0.1 + resolution: "promise-retry@npm:2.0.1" + dependencies: + err-code: "npm:^2.0.2" + retry: "npm:^0.12.0" + checksum: 10c0/9c7045a1a2928094b5b9b15336dcd2a7b1c052f674550df63cc3f36cd44028e5080448175b6f6ca32b642de81150f5e7b1a98b728f15cb069f2dd60ac2616b96 languageName: node linkType: hard @@ -1091,6 +1850,20 @@ __metadata: languageName: node linkType: hard +"resolve-pkg-maps@npm:^1.0.0": + version: 1.0.0 + resolution: "resolve-pkg-maps@npm:1.0.0" + checksum: 10c0/fb8f7bbe2ca281a73b7ef423a1cbc786fb244bd7a95cbe5c3fba25b27d327150beca8ba02f622baea65919a57e061eb5005204daa5f93ed590d9b77463a567ab + languageName: node + linkType: hard + +"retry@npm:^0.12.0": + version: 0.12.0 + resolution: "retry@npm:0.12.0" + checksum: 10c0/59933e8501727ba13ad73ef4a04d5280b3717fd650408460c987392efe9d7be2040778ed8ebe933c5cbd63da3dcc37919c141ef8af0a54a6e4fca5a2af177bfe + languageName: node + linkType: hard + "reusify@npm:^1.0.4": version: 1.0.4 resolution: "reusify@npm:1.0.4" @@ -1098,6 +1871,17 @@ __metadata: languageName: node linkType: hard +"rimraf@npm:^5.0.5": + version: 5.0.10 + resolution: "rimraf@npm:5.0.10" + dependencies: + glob: "npm:^10.3.7" + bin: + rimraf: dist/esm/bin.mjs + checksum: 10c0/7da4fd0e15118ee05b918359462cfa1e7fe4b1228c7765195a45b55576e8c15b95db513b8466ec89129666f4af45ad978a3057a02139afba1a63512a2d9644cc + languageName: node + linkType: hard + "run-parallel@npm:^1.1.9": version: 1.2.0 resolution: "run-parallel@npm:1.2.0" @@ -1107,7 +1891,14 @@ __metadata: languageName: node linkType: hard -"semver@npm:^7.6.0": +"safer-buffer@npm:>= 2.1.2 < 3.0.0": + version: 2.1.2 + resolution: "safer-buffer@npm:2.1.2" + checksum: 10c0/7e3c8b2e88a1841c9671094bbaeebd94448111dd90a81a1f606f3f67708a6ec57763b3b47f06da09fc6054193e0e6709e77325415dc8422b04497a8070fa02d4 + languageName: node + linkType: hard + +"semver@npm:^7.3.5, semver@npm:^7.6.0": version: 7.6.3 resolution: "semver@npm:7.6.3" bin: @@ -1144,14 +1935,106 @@ __metadata: eslint-config-prettier: "npm:^9.1.0" eslint-plugin-prettier: "npm:^5.2.1" globals: "npm:^15.13.0" - prettier: "npm:^3.4.1" + prettier: "npm:^3.4.2" + tsx: "npm:^4.19.2" typescript: "npm:^5.7.2" typescript-eslint: "npm:^8.17.0" bin: - sia-schema: dist/cli.js + sia: dist/cli/index.js languageName: unknown linkType: soft +"signal-exit@npm:^4.0.1": + version: 4.1.0 + resolution: "signal-exit@npm:4.1.0" + checksum: 10c0/41602dce540e46d599edba9d9860193398d135f7ff72cab629db5171516cfae628d21e7bfccde1bbfdf11c48726bc2a6d1a8fb8701125852fbfda7cf19c6aa83 + languageName: node + linkType: hard + +"smart-buffer@npm:^4.2.0": + version: 4.2.0 + resolution: "smart-buffer@npm:4.2.0" + checksum: 10c0/a16775323e1404dd43fabafe7460be13a471e021637bc7889468eb45ce6a6b207261f454e4e530a19500cc962c4cc5348583520843b363f4193cee5c00e1e539 + languageName: node + linkType: hard + +"socks-proxy-agent@npm:^8.0.3": + version: 8.0.4 + resolution: "socks-proxy-agent@npm:8.0.4" + dependencies: + agent-base: "npm:^7.1.1" + debug: "npm:^4.3.4" + socks: "npm:^2.8.3" + checksum: 10c0/345593bb21b95b0508e63e703c84da11549f0a2657d6b4e3ee3612c312cb3a907eac10e53b23ede3557c6601d63252103494caa306b66560f43af7b98f53957a + languageName: node + linkType: hard + +"socks@npm:^2.8.3": + version: 2.8.3 + resolution: "socks@npm:2.8.3" + dependencies: + ip-address: "npm:^9.0.5" + smart-buffer: "npm:^4.2.0" + checksum: 10c0/d54a52bf9325165770b674a67241143a3d8b4e4c8884560c4e0e078aace2a728dffc7f70150660f51b85797c4e1a3b82f9b7aa25e0a0ceae1a243365da5c51a7 + languageName: node + linkType: hard + +"sprintf-js@npm:^1.1.3": + version: 1.1.3 + resolution: "sprintf-js@npm:1.1.3" + checksum: 10c0/09270dc4f30d479e666aee820eacd9e464215cdff53848b443964202bf4051490538e5dd1b42e1a65cf7296916ca17640aebf63dae9812749c7542ee5f288dec + languageName: node + linkType: hard + +"ssri@npm:^12.0.0": + version: 12.0.0 + resolution: "ssri@npm:12.0.0" + dependencies: + minipass: "npm:^7.0.3" + checksum: 10c0/caddd5f544b2006e88fa6b0124d8d7b28208b83c72d7672d5ade44d794525d23b540f3396108c4eb9280dcb7c01f0bef50682f5b4b2c34291f7c5e211fd1417d + languageName: node + linkType: hard + +"string-width-cjs@npm:string-width@^4.2.0, string-width@npm:^4.1.0": + version: 4.2.3 + resolution: "string-width@npm:4.2.3" + dependencies: + emoji-regex: "npm:^8.0.0" + is-fullwidth-code-point: "npm:^3.0.0" + strip-ansi: "npm:^6.0.1" + checksum: 10c0/1e525e92e5eae0afd7454086eed9c818ee84374bb80328fc41217ae72ff5f065ef1c9d7f72da41de40c75fa8bb3dee63d92373fd492c84260a552c636392a47b + languageName: node + linkType: hard + +"string-width@npm:^5.0.1, string-width@npm:^5.1.2": + version: 5.1.2 + resolution: "string-width@npm:5.1.2" + dependencies: + eastasianwidth: "npm:^0.2.0" + emoji-regex: "npm:^9.2.2" + strip-ansi: "npm:^7.0.1" + checksum: 10c0/ab9c4264443d35b8b923cbdd513a089a60de339216d3b0ed3be3ba57d6880e1a192b70ae17225f764d7adbf5994e9bb8df253a944736c15a0240eff553c678ca + languageName: node + linkType: hard + +"strip-ansi-cjs@npm:strip-ansi@^6.0.1, strip-ansi@npm:^6.0.0, strip-ansi@npm:^6.0.1": + version: 6.0.1 + resolution: "strip-ansi@npm:6.0.1" + dependencies: + ansi-regex: "npm:^5.0.1" + checksum: 10c0/1ae5f212a126fe5b167707f716942490e3933085a5ff6c008ab97ab2f272c8025d3aa218b7bd6ab25729ca20cc81cddb252102f8751e13482a5199e873680952 + languageName: node + linkType: hard + +"strip-ansi@npm:^7.0.1": + version: 7.1.0 + resolution: "strip-ansi@npm:7.1.0" + dependencies: + ansi-regex: "npm:^6.0.1" + checksum: 10c0/a198c3762e8832505328cbf9e8c8381de14a4fa50a4f9b2160138158ea88c0f5549fb50cb13c651c3088f47e63a108b34622ec18c0499b6c8c3a5ddf6b305ac4 + languageName: node + linkType: hard + "strip-json-comments@npm:^3.1.1": version: 3.1.1 resolution: "strip-json-comments@npm:3.1.1" @@ -1178,6 +2061,20 @@ __metadata: languageName: node linkType: hard +"tar@npm:^7.4.3": + version: 7.4.3 + resolution: "tar@npm:7.4.3" + dependencies: + "@isaacs/fs-minipass": "npm:^4.0.0" + chownr: "npm:^3.0.0" + minipass: "npm:^7.1.2" + minizlib: "npm:^3.0.1" + mkdirp: "npm:^3.0.1" + yallist: "npm:^5.0.0" + checksum: 10c0/d4679609bb2a9b48eeaf84632b6d844128d2412b95b6de07d53d8ee8baf4ca0857c9331dfa510390a0727b550fd543d4d1a10995ad86cdf078423fbb8d99831d + languageName: node + linkType: hard + "to-regex-range@npm:^5.0.1": version: 5.0.1 resolution: "to-regex-range@npm:5.0.1" @@ -1203,6 +2100,22 @@ __metadata: languageName: node linkType: hard +"tsx@npm:^4.19.2": + version: 4.19.2 + resolution: "tsx@npm:4.19.2" + dependencies: + esbuild: "npm:~0.23.0" + fsevents: "npm:~2.3.3" + get-tsconfig: "npm:^4.7.5" + dependenciesMeta: + fsevents: + optional: true + bin: + tsx: dist/cli.mjs + checksum: 10c0/63164b889b1d170403e4d8753a6755dec371f220f5ce29a8e88f1f4d6085a784a12d8dc2ee669116611f2c72757ac9beaa3eea5c452796f541bdd2dc11753721 + languageName: node + linkType: hard + "type-check@npm:^0.4.0, type-check@npm:~0.4.0": version: 0.4.0 resolution: "type-check@npm:0.4.0" @@ -1255,6 +2168,24 @@ __metadata: languageName: node linkType: hard +"unique-filename@npm:^4.0.0": + version: 4.0.0 + resolution: "unique-filename@npm:4.0.0" + dependencies: + unique-slug: "npm:^5.0.0" + checksum: 10c0/38ae681cceb1408ea0587b6b01e29b00eee3c84baee1e41fd5c16b9ed443b80fba90c40e0ba69627e30855570a34ba8b06702d4a35035d4b5e198bf5a64c9ddc + languageName: node + linkType: hard + +"unique-slug@npm:^5.0.0": + version: 5.0.0 + resolution: "unique-slug@npm:5.0.0" + dependencies: + imurmurhash: "npm:^0.1.4" + checksum: 10c0/d324c5a44887bd7e105ce800fcf7533d43f29c48757ac410afd42975de82cc38ea2035c0483f4de82d186691bf3208ef35c644f73aa2b1b20b8e651be5afd293 + languageName: node + linkType: hard + "uri-js@npm:^4.2.2": version: 4.4.1 resolution: "uri-js@npm:4.4.1" @@ -1275,6 +2206,17 @@ __metadata: languageName: node linkType: hard +"which@npm:^5.0.0": + version: 5.0.0 + resolution: "which@npm:5.0.0" + dependencies: + isexe: "npm:^3.1.1" + bin: + node-which: bin/which.js + checksum: 10c0/e556e4cd8b7dbf5df52408c9a9dd5ac6518c8c5267c8953f5b0564073c66ed5bf9503b14d876d0e9c7844d4db9725fb0dcf45d6e911e17e26ab363dc3965ae7b + languageName: node + linkType: hard + "word-wrap@npm:^1.2.5": version: 1.2.5 resolution: "word-wrap@npm:1.2.5" @@ -1282,6 +2224,42 @@ __metadata: languageName: node linkType: hard +"wrap-ansi-cjs@npm:wrap-ansi@^7.0.0": + version: 7.0.0 + resolution: "wrap-ansi@npm:7.0.0" + dependencies: + ansi-styles: "npm:^4.0.0" + string-width: "npm:^4.1.0" + strip-ansi: "npm:^6.0.0" + checksum: 10c0/d15fc12c11e4cbc4044a552129ebc75ee3f57aa9c1958373a4db0292d72282f54373b536103987a4a7594db1ef6a4f10acf92978f79b98c49306a4b58c77d4da + languageName: node + linkType: hard + +"wrap-ansi@npm:^8.1.0": + version: 8.1.0 + resolution: "wrap-ansi@npm:8.1.0" + dependencies: + ansi-styles: "npm:^6.1.0" + string-width: "npm:^5.0.1" + strip-ansi: "npm:^7.0.1" + checksum: 10c0/138ff58a41d2f877eae87e3282c0630fc2789012fc1af4d6bd626eeb9a2f9a65ca92005e6e69a75c7b85a68479fe7443c7dbe1eb8fbaa681a4491364b7c55c60 + languageName: node + linkType: hard + +"yallist@npm:^4.0.0": + version: 4.0.0 + resolution: "yallist@npm:4.0.0" + checksum: 10c0/2286b5e8dbfe22204ab66e2ef5cc9bbb1e55dfc873bbe0d568aa943eb255d131890dfd5bf243637273d31119b870f49c18fcde2c6ffbb7a7a092b870dc90625a + languageName: node + linkType: hard + +"yallist@npm:^5.0.0": + version: 5.0.0 + resolution: "yallist@npm:5.0.0" + checksum: 10c0/a499c81ce6d4a1d260d4ea0f6d49ab4da09681e32c3f0472dee16667ed69d01dae63a3b81745a24bd78476ec4fcf856114cb4896ace738e01da34b2c42235416 + languageName: node + linkType: hard + "yocto-queue@npm:^0.1.0": version: 0.1.0 resolution: "yocto-queue@npm:0.1.0" From bd3402eb3bac3988a39a1f734239d4b0b76c2f48 Mon Sep 17 00:00:00 2001 From: Andrey Luiz Date: Mon, 9 Dec 2024 12:58:32 +0100 Subject: [PATCH 2/2] Move files for a better directory structure --- package.json | 4 ++-- src/{cli/index.ts => cli.ts} | 6 +++--- src/{cli => generator}/common/js/index.ts | 0 src/{cli => generator}/common/js/maps.ts | 0 src/{cli => generator}/common/js/strings.ts | 0 src/{cli => generator}/common/types.ts | 0 src/{cli/common => generator}/index.ts | 6 +++--- src/{cli => generator}/javascript.ts | 2 +- 8 files changed, 9 insertions(+), 9 deletions(-) rename src/{cli/index.ts => cli.ts} (91%) rename src/{cli => generator}/common/js/index.ts (100%) rename src/{cli => generator}/common/js/maps.ts (100%) rename src/{cli => generator}/common/js/strings.ts (100%) rename src/{cli => generator}/common/types.ts (100%) rename src/{cli/common => generator}/index.ts (85%) rename src/{cli => generator}/javascript.ts (98%) diff --git a/package.json b/package.json index ca5f22f..516aa0e 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "commander": "^12.1.0" }, "bin": { - "sia": "dist/cli/index.js" + "sia": "dist/cli.js" }, "devDependencies": { "@eslint/js": "^9.16.0", @@ -24,7 +24,7 @@ "type": "module", "scripts": { "build": "tsc", - "start": "tsx src/cli/index.ts", + "start": "tsx src/cli.ts", "lint": "eslint src/**/*.ts", "format": "prettier --write .", "ts-check": "tsc --noEmit" diff --git a/src/cli/index.ts b/src/cli.ts similarity index 91% rename from src/cli/index.ts rename to src/cli.ts index a79c516..b3175fb 100644 --- a/src/cli/index.ts +++ b/src/cli.ts @@ -3,9 +3,9 @@ import { ILexingError, IRecognitionException } from "chevrotain"; import { Command } from "commander"; import { readFileSync, writeFileSync } from "fs"; -import { compile } from "../index.js"; -import { logError } from "../utils/log.js"; -import { generateSia, getExtension } from "./common/index.js"; +import { generateSia, getExtension } from "./generator/index.js"; +import { compile } from "./index.js"; +import { logError } from "./utils/log.js"; const program = new Command(); diff --git a/src/cli/common/js/index.ts b/src/generator/common/js/index.ts similarity index 100% rename from src/cli/common/js/index.ts rename to src/generator/common/js/index.ts diff --git a/src/cli/common/js/maps.ts b/src/generator/common/js/maps.ts similarity index 100% rename from src/cli/common/js/maps.ts rename to src/generator/common/js/maps.ts diff --git a/src/cli/common/js/strings.ts b/src/generator/common/js/strings.ts similarity index 100% rename from src/cli/common/js/strings.ts rename to src/generator/common/js/strings.ts diff --git a/src/cli/common/types.ts b/src/generator/common/types.ts similarity index 100% rename from src/cli/common/types.ts rename to src/generator/common/types.ts diff --git a/src/cli/common/index.ts b/src/generator/index.ts similarity index 85% rename from src/cli/common/index.ts rename to src/generator/index.ts index 43be021..ffbd492 100644 --- a/src/cli/common/index.ts +++ b/src/generator/index.ts @@ -1,6 +1,6 @@ -import { SchemaDefinition } from "../../visitor.js"; -import { generateJs, isJsProject } from "../javascript.js"; -import { Extension } from "./types.js"; +import { SchemaDefinition } from "../visitor.js"; +import { Extension } from "./common/types.js"; +import { generateJs, isJsProject } from "./javascript.js"; export const getExtension = (extension?: string) => { if (extension && !Object.values(Extension).includes(extension as Extension)) { diff --git a/src/cli/javascript.ts b/src/generator/javascript.ts similarity index 98% rename from src/cli/javascript.ts rename to src/generator/javascript.ts index f6383c6..f6f90a7 100644 --- a/src/cli/javascript.ts +++ b/src/generator/javascript.ts @@ -2,7 +2,6 @@ import { existsSync } from "fs"; import path from "path"; import * as prettier from "prettier"; import { SchemaDefinition } from "../visitor.js"; -import { createLineBreakString } from "./common/index.js"; import { generateAttribute, getRequiredSerializers, @@ -24,6 +23,7 @@ import { createSiaResultString, } from "./common/js/strings.js"; import { Generator, SiaType } from "./common/types.js"; +import { createLineBreakString } from "./index.js"; export const isJsProject = () => { return existsSync(path.join(process.cwd(), "package.json"));