Comparing version 1.0.5 to 1.0.6
74
index.js
@@ -12,2 +12,4 @@ var __create = Object.create, __defProp = Object.defineProperty, __getProtoOf = Object.getPrototypeOf, __hasOwnProp = Object.prototype.hasOwnProperty, __getOwnPropNames = Object.getOwnPropertyNames, __getOwnPropDesc = Object.getOwnPropertyDescriptor; | ||
}, __toModule = (module2) => module2 && module2.__esModule ? module2 : __exportStar(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", {value: module2, enumerable: !0})), module2); | ||
// index.ts | ||
__markAsModule(exports); | ||
@@ -24,7 +26,28 @@ __export(exports, { | ||
}); | ||
var fs = __toModule(require("fs")), import_decorators = __toModule(require("./decorators")), path = __toModule(require("path")); | ||
function trim(input) { | ||
return input.trim(); | ||
var fs = __toModule(require("fs")); | ||
// decorators.ts | ||
var esbuild = __toModule(require("esbuild")), import_fast_glob = __toModule(require("fast-glob")), DecoratorType; | ||
(function(DecoratorType2) { | ||
DecoratorType2[DecoratorType2.property = 0] = "property", DecoratorType2[DecoratorType2.klass = 1] = "klass"; | ||
})(DecoratorType || (DecoratorType = {})); | ||
async function decorators(decoratorGlob = "./**/*.{decorator.ts,dec.ts,decorators.ts,decky.ts}", additionalConfig = {}) { | ||
let entryPoints = additionalConfig?.entryPoints?.length ? additionalConfig.entryPoints : await import_fast_glob.default(decoratorGlob); | ||
return await esbuild.build({ | ||
minify: !1, | ||
minifySyntax: !0, | ||
format: "cjs", | ||
sourcemap: "both", | ||
outdir: ".", | ||
outbase: ".", | ||
...additionalConfig, | ||
platform: "node", | ||
entryPoints, | ||
bundle: !1 | ||
}), entryPoints; | ||
} | ||
class ProcessorError extends Error { | ||
// index.ts | ||
var path = __toModule(require("path")); | ||
var ProcessorError = class extends Error { | ||
constructor(message, file, lineNumber, lineText, column) { | ||
@@ -42,9 +65,9 @@ super(message); | ||
} | ||
} | ||
}; | ||
function buildDecoratorProcessor(decoratorsModuleMap) { | ||
const fileMapping = {}, allPrefixes = new Set(); | ||
let fileMapping = {}, allPrefixes = new Set(); | ||
for (let moduleName in decoratorsModuleMap) { | ||
const decorators = decoratorsModuleMap[moduleName], decoratorKeys = Object.keys(decorators).sort().reverse(), decoratorPrefixes = decoratorKeys.map((a) => a.toString()), decoratorFunctions = new Array(decoratorKeys.length), flattenedFuncs = decoratorKeys.map((a) => decorators[a].callback); | ||
let decorators2 = decoratorsModuleMap[moduleName], decoratorKeys = Object.keys(decorators2).sort().reverse(), decoratorPrefixes = decoratorKeys.map((a) => a.toString()), decoratorFunctions = new Array(decoratorKeys.length), flattenedFuncs = decoratorKeys.map((a) => decorators2[a].callback); | ||
for (let i = 0; i < decoratorKeys.length; i++) { | ||
const key = decoratorKeys[i], prefix = decoratorPrefixes[i], length = key.length, decoratorFunc = flattenedFuncs[i], processDecorator = async (prefixStart, result) => { | ||
let key = decoratorKeys[i], prefix = decoratorPrefixes[i], length = key.length, decoratorFunc = flattenedFuncs[i], processDecorator = async (prefixStart, result) => { | ||
let code = result.code, prefixEnd = prefixStart + length, argStart = prefixEnd, lineEnd = code.indexOf(` | ||
@@ -84,3 +107,3 @@ `, prefixStart), argEnd = -1, argList; | ||
semicolonIndex > -1 && (typeName = typeName.substring(0, semicolonIndex)), result.code = code; | ||
const newCode = await decoratorFunc({ | ||
let newCode = await decoratorFunc({ | ||
key: key2, | ||
@@ -103,3 +126,3 @@ type: typeName, | ||
} | ||
const modulesToCheck = Object.keys(fileMapping); | ||
let modulesToCheck = Object.keys(fileMapping); | ||
return { | ||
@@ -110,4 +133,3 @@ process: async (code, filePath) => { | ||
continue; | ||
const {decoratorFunctions, decoratorPrefixes} = fileMapping[decoratorModuleName]; | ||
let startIndex = -1, symbolI = code.lastIndexOf("@") - 1, _prefixI = -1; | ||
let {decoratorFunctions, decoratorPrefixes} = fileMapping[decoratorModuleName], startIndex = -1, symbolI = code.lastIndexOf("@") - 1, _prefixI = -1; | ||
if (symbolI < -1) | ||
@@ -172,3 +194,3 @@ return {contents: code, note: null}; | ||
} | ||
const staticDecoratorCode = [property, klass].map((stub) => `/* @__PURE__ */ | ||
var staticDecoratorCode = [property, klass].map((stub) => `/* @__PURE__ */ | ||
export function ${stub}(...args){return args;} | ||
@@ -183,4 +205,4 @@ `).join(` | ||
} | ||
function plugin(decorators) { | ||
const {prefixes, process: process2} = buildDecoratorProcessor(decorators); | ||
function plugin(decorators2) { | ||
let {prefixes, process: process2} = buildDecoratorProcessor(decorators2); | ||
function isPotentialMatch(content) { | ||
@@ -193,3 +215,3 @@ for (let prefix of prefixes) | ||
function onLoadDecoratorStub(args) { | ||
const stub = require(args.path).decorators; | ||
let stub = require(args.path).decorators; | ||
return { | ||
@@ -210,3 +232,3 @@ contents: Object.keys(stub).map((stub2) => `/* @__PURE__ */ | ||
}; | ||
const {note, contents: _contents} = await process2(contents, args.path) ?? {}; | ||
let {note, contents: _contents} = await process2(contents, args.path) ?? {}; | ||
return { | ||
@@ -219,3 +241,3 @@ contents: _contents, | ||
async function onLoadTS(args) { | ||
const contents = await fs.promises.readFile(args.path, "utf8"); | ||
let contents = await fs.promises.readFile(args.path, "utf8"); | ||
if (!isPotentialMatch(contents)) | ||
@@ -226,3 +248,3 @@ return { | ||
}; | ||
const {note, contents: _contents} = await process2(contents, args.path) ?? {}; | ||
let {note, contents: _contents} = await process2(contents, args.path) ?? {}; | ||
return { | ||
@@ -236,4 +258,4 @@ contents: _contents, | ||
name: "design-time-decorators", | ||
setup(build) { | ||
build.onResolve({filter: /\.(decorator|dec)\.(ts)$/}, onResolveDecorator), build.onResolve({filter: /\.(decorator|dec)\.(tsx)$/}, onResolveDecorator), build.onResolve({filter: /^decky$/}, onResolveStaticDecorators), build.onLoad({filter: /^decky$/, namespace: "decky"}, onLoadStaticDecorators), build.onLoad({filter: /\.(decorator|dec)\.(ts)$/, namespace: "decorator-stub"}, onLoadDecoratorStub), build.onLoad({filter: /\.(decorator|dec)\.(tsx)$/, namespace: "decorator-stub"}, onLoadDecoratorStub), build.onLoad({filter: /\.(ts)$/}, onLoadTS), build.onLoad({filter: /\.(tsx)$/}, onLoadTSX); | ||
setup(build2) { | ||
build2.onResolve({filter: /\.(decorator|dec)\.(ts)$/}, onResolveDecorator), build2.onResolve({filter: /\.(decorator|dec)\.(tsx)$/}, onResolveDecorator), build2.onResolve({filter: /^decky$/}, onResolveStaticDecorators), build2.onLoad({filter: /^decky$/, namespace: "decky"}, onLoadStaticDecorators), build2.onLoad({filter: /\.(decorator|dec)\.(ts)$/, namespace: "decorator-stub"}, onLoadDecoratorStub), build2.onLoad({filter: /\.(decorator|dec)\.(tsx)$/, namespace: "decorator-stub"}, onLoadDecoratorStub), build2.onLoad({filter: /\.(ts)$/}, onLoadTS), build2.onLoad({filter: /\.(tsx)$/}, onLoadTSX); | ||
} | ||
@@ -245,3 +267,3 @@ }; | ||
callback, | ||
type: import_decorators.DecoratorType.property | ||
type: DecoratorType.property | ||
}; | ||
@@ -252,3 +274,3 @@ } | ||
callback, | ||
type: import_decorators.DecoratorType.property | ||
type: DecoratorType.property | ||
}; | ||
@@ -259,7 +281,7 @@ } | ||
callback, | ||
type: import_decorators.DecoratorType.klass | ||
type: DecoratorType.klass | ||
}; | ||
} | ||
async function load(decoratorsGlob, additionalConfig) { | ||
const {decorators} = require("./decorators"), entryPoints = await decorators(decoratorsGlob, additionalConfig), files = {}; | ||
let entryPoints = await decorators(decoratorsGlob, additionalConfig), files = {}; | ||
for (let file of entryPoints) | ||
@@ -271,2 +293,2 @@ Object.assign(files, { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["index.ts"],
  "sourcesContent": ["import { BuildOptions, OnLoadResult, PartialNote } from \"esbuild\";\nimport * as fs from \"fs\";\nimport { DecoratorType } from \"./decorators\";\nimport * as path from \"path\";\ntype Qualifier = \"public\" | \"private\" | \"protected\" | null;\n\ntype DesignTimeProperty<T = any[]> = {\n  key: string;\n  type?: string;\n  args?: T;\n  isStatic?: boolean;\n  qualifier?: Qualifier;\n  metadata?: DecoratorResult;\n};\n\ntype DesignTimePropertyDecoratorFunction<T> = (\n  property: DesignTimeProperty<T>\n) => void | any;\n\nexport type DesignTimePropertyDecorator<T> = (\n  ...args: string[]\n) => DesignTimePropertyDecoratorFunction<T>;\n\ntype DesignTimeClass<T = any[]> = {\n  className: string;\n  args?: T;\n  metadata?: DecoratorResult;\n};\n\ntype DesignTimeClassFunction<T> = (klass: DesignTimeClass<T>) => void | any;\n\nexport type DesignTimeClassDecorator<T> = () => DesignTimeClassFunction<T>;\n\nexport type DecoratorsMap = {\n  [modulePath: string]: {\n    [name: string]:\n      | DesignTimePropertyDecorator<any>\n      | DesignTimeClassDecorator<any>;\n  };\n};\n\ninterface DecoratorResult {\n  readonly code: string;\n  readonly originalSource: string;\n  readonly filePath: string;\n  readonly startIndex: number;\n  readonly stopIndex: number;\n}\n\ntype DecoratorProcessor = (\n  prefixStart: number,\n  result: DecoratorResult\n) => Promise<boolean>;\n\nfunction trim(input: string) {\n  return input.trim();\n}\n\nclass ProcessorError extends Error {\n  constructor(\n    message: string,\n    file: string,\n    lineNumber: number,\n    lineText: string,\n    column?: number\n  ) {\n    super(message);\n    this.note = {\n      text: message,\n      location: {\n        file,\n        line: lineNumber,\n        lineText,\n\n        column,\n      },\n    };\n  }\n  note: PartialNote;\n}\n\nfunction buildDecoratorProcessor(decoratorsModuleMap: DecoratorsMap) {\n  const fileMapping = {};\n  const allPrefixes = new Set();\n  for (let moduleName in decoratorsModuleMap) {\n    const decorators = decoratorsModuleMap[moduleName];\n    const decoratorKeys = Object.keys(decorators).sort().reverse();\n    const decoratorPrefixes = decoratorKeys.map((a) => a.toString());\n    const decoratorFunctions: Array<DecoratorProcessor> = new Array(\n      decoratorKeys.length\n    );\n    const flattenedFuncs = decoratorKeys.map(\n      (a) => (decorators[a] as any).callback\n    );\n\n    for (let i = 0; i < decoratorKeys.length; i++) {\n      const key = decoratorKeys[i];\n      const prefix = decoratorPrefixes[i];\n      const length = key.length;\n      const decoratorFunc:\n        | DesignTimeClassFunction<any>\n        | DesignTimePropertyDecoratorFunction<any> = flattenedFuncs[i];\n\n      const processDecorator: DecoratorProcessor = async (\n        prefixStart,\n        result\n      ) => {\n        let code = result.code;\n        let prefixEnd = prefixStart + length;\n        let argStart = prefixEnd;\n        let lineEnd = code.indexOf(\"\\n\", prefixStart);\n        let argEnd = -1;\n        let argList;\n        if (code[argStart++] === \"(\") {\n          argEnd = code.indexOf(\")\", argStart);\n          if (argEnd - 1 > argStart) {\n            if (argEnd < 0)\n              throw new ProcessorError(\n                `Missing ) for ${prefix}`,\n                result.filePath,\n                result.code.substring(0, prefixStart).split(\"\\n\").length,\n                result.code.split(\"\\n\")[\n                  result.code.substring(0, prefixStart).split(\"\\n\").length\n                ],\n                prefixEnd\n              );\n\n            try {\n              argList = JSON.parse(\n                \"[\" + code.substring(argStart, argEnd) + \"]\"\n              );\n            } catch (exception) {\n              throw new ProcessorError(\n                `Arguments to ${prefix} must be JSON. Received: [${code.substring(\n                  argStart,\n                  argEnd\n                )}]`,\n                result.filePath,\n                result.code.substring(0, prefixStart).split(\"\\n\").length - 1,\n                result.code.split(\"\\n\")[\n                  result.code.substring(0, prefixStart).split(\"\\n\").length - 1\n                ],\n                argStart\n              );\n            }\n          } else {\n            argStart = -1;\n            argList = [];\n          }\n        } else {\n          argStart = -1;\n          argList = [];\n        }\n        let nextLineStart = lineEnd + 1;\n        let nextLineEnd = code.indexOf(\"\\n\", nextLineStart);\n        const originalLine = code.substring(nextLineStart, nextLineEnd).trim();\n        let nextLine = originalLine;\n        let isStatic = false;\n        let qualifier: Qualifier = null;\n\n        if (nextLine.startsWith(\"export \")) {\n          nextLine = nextLine.substring(\"export \".length).trim();\n        }\n\n        if (nextLine.startsWith(\"public \")) {\n          qualifier = \"public\";\n          nextLine = nextLine.substring(\"public\".length);\n        } else if (nextLine.startsWith(\"private \")) {\n          qualifier = \"private\";\n          nextLine = nextLine.substring(\"private\".length);\n        } else if (nextLine.startsWith(\"protected \")) {\n          qualifier = \"protected\";\n          nextLine = nextLine.substring(\"protected\".length);\n        }\n\n        nextLine = nextLine.trim();\n        let isClass = nextLine.startsWith(\"class \");\n\n        if (!isClass) {\n          isStatic = nextLine.startsWith(\"static \");\n          if (isStatic) {\n            nextLine.substring(\"static \".length);\n          }\n        }\n\n        if (isClass) {\n          nextLine = nextLine.substring(\"class \".length);\n          // TODO: object pooling\n          await (decoratorFunc as DesignTimeClassFunction<any>)({\n            className: nextLine.substring(0, nextLine.indexOf(\" \")),\n            args: argList,\n            metadata: result,\n          } as DesignTimeClass);\n          return false;\n        } else {\n          // let colon\n          let typeSeparatorIndex = nextLine.indexOf(\":\");\n          let key = nextLine.substring(0, typeSeparatorIndex).trim();\n          let typeName = nextLine.substring(typeSeparatorIndex + 1).trim();\n\n          let semicolonIndex = typeName.indexOf(\";\");\n          if (semicolonIndex > -1) {\n            typeName = typeName.substring(0, semicolonIndex);\n          }\n\n          (result.code as any) = code;\n          // TODO: object pooling\n          const newCode = await (decoratorFunc as DesignTimePropertyDecoratorFunction<any>)(\n            {\n              key,\n              type: typeName,\n              args: argList,\n              isStatic,\n              qualifier,\n              metadata: result,\n            }\n          );\n          if (!newCode && newCode !== \"\") {\n            (result.startIndex as any) = prefixStart;\n            (result.stopIndex as any) = prefixEnd;\n            (result.code as any) = newCode || \"\";\n            return false;\n          }\n\n          (result.startIndex as any) = prefixStart - 1;\n          (result.stopIndex as any) = nextLineEnd - 1;\n          (result.code as any) = newCode || \"\";\n          return true;\n        }\n      };\n\n      decoratorFunctions[i] = processDecorator;\n    }\n    fileMapping[path.basename(moduleName, path.extname(moduleName))] = {\n      decoratorFunctions,\n      decoratorPrefixes,\n    };\n    decoratorPrefixes.forEach((prefix) => allPrefixes.add(prefix));\n  }\n\n  const modulesToCheck = Object.keys(fileMapping);\n  return {\n    process: async (code: string, filePath: string) => {\n      for (let decoratorModuleName of modulesToCheck) {\n        // There's gotta be a faster & less hacky way to do this without a full AST.\n        if (!code.includes(decoratorModuleName)) continue;\n\n        const { decoratorFunctions, decoratorPrefixes } = fileMapping[\n          decoratorModuleName\n        ];\n        let startIndex = -1;\n        let symbolI = code.lastIndexOf(\"@\") - 1;\n        let _prefixI = -1;\n        if (symbolI < -1) return { contents: code, note: null };\n        if (symbolI < 0) symbolI = 0;\n\n        let result = {\n          code,\n          originalSource: code,\n          filePath,\n          startIndex: -1,\n          stopIndex: -1,\n        };\n\n        let prefixI = -1;\n        for (_prefixI = 0; _prefixI < decoratorPrefixes.length; _prefixI++) {\n          result.startIndex = code.indexOf(\n            decoratorPrefixes[_prefixI],\n            symbolI\n          );\n          if (result.startIndex > -1) {\n            prefixI = _prefixI;\n            break;\n          }\n        }\n\n        let prefix = \"\";\n\n        while (prefixI > -1) {\n          prefix = decoratorPrefixes[prefixI];\n          if (result.startIndex > -1) {\n            let _code = result.code;\n            let didChange = false;\n            try {\n              didChange = await decoratorFunctions[prefixI](\n                result.startIndex,\n                result\n              );\n            } catch (exception) {\n              if (exception instanceof ProcessorError) {\n                return {\n                  contents: \"\",\n                  note: exception.note,\n                };\n              } else {\n                throw exception;\n              }\n            }\n\n            if (didChange) {\n              if (result.startIndex > -1 && result.stopIndex > -1) {\n                result.code =\n                  _code.substring(0, result.startIndex) +\n                  result.code +\n                  _code.substring(result.stopIndex);\n              }\n            } else {\n              result.code =\n                _code.substring(0, result.startIndex - 1) +\n                _code.substring(_code.indexOf(\"\\n\", result.startIndex));\n            }\n\n            result.startIndex = result.stopIndex = -1;\n          }\n\n          prefixI = -1;\n          for (_prefixI = 0; _prefixI < decoratorPrefixes.length; _prefixI++) {\n            symbolI = result.code.lastIndexOf(\"@\");\n            if (symbolI === -1) break;\n\n            result.startIndex = result.code.indexOf(\n              decoratorPrefixes[_prefixI],\n              symbolI\n            );\n            if (result.startIndex > -1) {\n              prefixI = _prefixI;\n              break;\n            }\n          }\n        }\n\n        return {\n          contents: result.code,\n          note: null,\n        };\n      }\n    },\n    prefixes: [...allPrefixes],\n  };\n}\n\nfunction onResolveDecorator(args) {\n  return {\n    path: args.path,\n    namespace: \"decorator-stub\",\n  };\n}\n\nfunction onResolveStaticDecorators(args) {\n  return {\n    path: args.path,\n    namespace: \"decky\",\n  };\n}\n\nconst staticDecoratorCode = [property, klass]\n  .map(\n    (stub) =>\n      `/* @__PURE__ */\\nexport function ${stub}(...args){return args;}\\n`\n  )\n  .join(\"\\n\");\n\nfunction onLoadStaticDecorators(args) {\n  return {\n    contents: staticDecoratorCode,\n    loader: \"js\",\n  };\n}\n\nexport function plugin(decorators: DecoratorsMap) {\n  const { prefixes, process } = buildDecoratorProcessor(decorators);\n\n  function isPotentialMatch(content: string) {\n    for (let prefix of prefixes) {\n      if (content.includes(prefix as string)) return true;\n    }\n\n    return false;\n  }\n\n  function onLoadDecoratorStub(args) {\n    const stub = require(args.path).decorators;\n\n    return {\n      contents: Object.keys(stub)\n        .map(\n          (stub) =>\n            `/* @__PURE__ */\\nexport function ${stub}(...args){return args;}\\n`\n        )\n        .join(\"\\n\"),\n      loader: \"ts\",\n    };\n  }\n\n  async function onLoadTSX(args): Promise<OnLoadResult> {\n    let contents: string = await fs.promises.readFile(args.path, \"utf8\");\n    if (!isPotentialMatch(contents))\n      return {\n        contents,\n        loader: \"tsx\",\n      };\n\n    const { note, contents: _contents } =\n      (await process(contents, args.path)) ?? {};\n\n    return {\n      contents: _contents,\n      errors: note\n        ? [{ location: note.location, detail: note.text }]\n        : undefined,\n      loader: \"tsx\",\n    };\n  }\n\n  async function onLoadTS(args): Promise<OnLoadResult> {\n    const contents: string = await fs.promises.readFile(args.path, \"utf8\");\n    if (!isPotentialMatch(contents))\n      return {\n        contents,\n        loader: \"ts\",\n      };\n\n    const { note, contents: _contents } =\n      (await process(contents, args.path)) ?? {};\n\n    return {\n      contents: _contents,\n      errors: note ? [{ location: note.location, text: note.text }] : undefined,\n      loader: \"ts\",\n    };\n  }\n\n  return {\n    name: \"design-time-decorators\",\n    setup(build) {\n      build.onResolve(\n        { filter: /\\.(decorator|dec)\\.(ts)$/ },\n        onResolveDecorator\n      );\n      build.onResolve(\n        { filter: /\\.(decorator|dec)\\.(tsx)$/ },\n        onResolveDecorator\n      );\n      build.onResolve({ filter: /^decky$/ }, onResolveStaticDecorators);\n      build.onLoad(\n        { filter: /^decky$/, namespace: \"decky\" },\n        onLoadStaticDecorators\n      );\n      build.onLoad(\n        { filter: /\\.(decorator|dec)\\.(ts)$/, namespace: \"decorator-stub\" },\n        onLoadDecoratorStub\n      );\n      build.onLoad(\n        { filter: /\\.(decorator|dec)\\.(tsx)$/, namespace: \"decorator-stub\" },\n        onLoadDecoratorStub\n      );\n      build.onLoad({ filter: /\\.(ts)$/ }, onLoadTS);\n      build.onLoad({ filter: /\\.(tsx)$/ }, onLoadTSX);\n    },\n  };\n}\n\ntype OptionalPropertyDescriptor<T> = T extends Exclude<\n  (number | string)[],\n  undefined\n>\n  ? (...args: T) => PropertyDecorator\n  : void;\n\nexport function property<T>(\n  callback: DesignTimePropertyDecoratorFunction<T>\n): OptionalPropertyDescriptor<T> {\n  return {\n    callback,\n    type: DecoratorType.property,\n  } as any;\n}\n\nexport function propertyVoid(\n  callback: DesignTimePropertyDecoratorFunction<never>\n): PropertyDecorator {\n  return {\n    callback,\n    type: DecoratorType.property,\n  } as any;\n}\n\nexport { property as p, propertyVoid as pV };\nexport { klass as c };\n\nexport function klass<T extends any[] = []>(\n  callback: DesignTimeClassFunction<T>\n): (...args: T) => ClassDecorator {\n  return <any | void>{\n    callback,\n    type: DecoratorType.klass,\n  };\n}\n\nexport async function load(\n  decoratorsGlob?: string,\n  additionalConfig?: Partial<BuildOptions>\n) {\n  const { decorators } = require(\"./decorators\");\n  const entryPoints = await decorators(decoratorsGlob, additionalConfig);\n  const files = {};\n  for (let file of entryPoints) {\n    Object.assign(files, {\n      [file]: require(path.join(\n        process.cwd(),\n        path.dirname(file),\n        path.basename(file).replace(\".ts\", \".js\")\n      )).decorators,\n    });\n  }\n\n  return plugin(files);\n}\n"],
  "mappings": "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",
  "names": []
}
 | ||
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["index.ts", "decorators.ts"],
  "sourcesContent": ["import { BuildOptions, OnLoadResult, PartialNote } from \"esbuild\";\nimport * as fs from \"fs\";\nimport { DecoratorType, decorators } from \"decky/decorators\";\nimport * as path from \"path\";\ntype Qualifier = \"public\" | \"private\" | \"protected\" | null;\n\ntype DesignTimeProperty<T = any[]> = {\n  key: string;\n  type?: string;\n  args?: T;\n  isStatic?: boolean;\n  qualifier?: Qualifier;\n  metadata?: DecoratorResult;\n};\n\ntype DesignTimePropertyDecoratorFunction<T> = (\n  property: DesignTimeProperty<T>\n) => void | any;\n\nexport type DesignTimePropertyDecorator<T> = (\n  ...args: string[]\n) => DesignTimePropertyDecoratorFunction<T>;\n\ntype DesignTimeClass<T = any[]> = {\n  className: string;\n  args?: T;\n  metadata?: DecoratorResult;\n};\n\ntype DesignTimeClassFunction<T> = (klass: DesignTimeClass<T>) => void | any;\n\nexport type DesignTimeClassDecorator<T> = () => DesignTimeClassFunction<T>;\n\nexport type DecoratorsMap = {\n  [modulePath: string]: {\n    [name: string]:\n      | DesignTimePropertyDecorator<any>\n      | DesignTimeClassDecorator<any>;\n  };\n};\n\ninterface DecoratorResult {\n  readonly code: string;\n  readonly originalSource: string;\n  readonly filePath: string;\n  readonly startIndex: number;\n  readonly stopIndex: number;\n}\n\ntype DecoratorProcessor = (\n  prefixStart: number,\n  result: DecoratorResult\n) => Promise<boolean>;\n\nfunction trim(input: string) {\n  return input.trim();\n}\n\nclass ProcessorError extends Error {\n  constructor(\n    message: string,\n    file: string,\n    lineNumber: number,\n    lineText: string,\n    column?: number\n  ) {\n    super(message);\n    this.note = {\n      text: message,\n      location: {\n        file,\n        line: lineNumber,\n        lineText,\n\n        column,\n      },\n    };\n  }\n  note: PartialNote;\n}\n\nfunction buildDecoratorProcessor(decoratorsModuleMap: DecoratorsMap) {\n  const fileMapping = {};\n  const allPrefixes = new Set();\n  for (let moduleName in decoratorsModuleMap) {\n    const decorators = decoratorsModuleMap[moduleName];\n    const decoratorKeys = Object.keys(decorators).sort().reverse();\n    const decoratorPrefixes = decoratorKeys.map((a) => a.toString());\n    const decoratorFunctions: Array<DecoratorProcessor> = new Array(\n      decoratorKeys.length\n    );\n    const flattenedFuncs = decoratorKeys.map(\n      (a) => (decorators[a] as any).callback\n    );\n\n    for (let i = 0; i < decoratorKeys.length; i++) {\n      const key = decoratorKeys[i];\n      const prefix = decoratorPrefixes[i];\n      const length = key.length;\n      const decoratorFunc:\n        | DesignTimeClassFunction<any>\n        | DesignTimePropertyDecoratorFunction<any> = flattenedFuncs[i];\n\n      const processDecorator: DecoratorProcessor = async (\n        prefixStart,\n        result\n      ) => {\n        let code = result.code;\n        let prefixEnd = prefixStart + length;\n        let argStart = prefixEnd;\n        let lineEnd = code.indexOf(\"\\n\", prefixStart);\n        let argEnd = -1;\n        let argList;\n        if (code[argStart++] === \"(\") {\n          argEnd = code.indexOf(\")\", argStart);\n          if (argEnd - 1 > argStart) {\n            if (argEnd < 0)\n              throw new ProcessorError(\n                `Missing ) for ${prefix}`,\n                result.filePath,\n                result.code.substring(0, prefixStart).split(\"\\n\").length,\n                result.code.split(\"\\n\")[\n                  result.code.substring(0, prefixStart).split(\"\\n\").length\n                ],\n                prefixEnd\n              );\n\n            try {\n              argList = JSON.parse(\n                \"[\" + code.substring(argStart, argEnd) + \"]\"\n              );\n            } catch (exception) {\n              throw new ProcessorError(\n                `Arguments to ${prefix} must be JSON. Received: [${code.substring(\n                  argStart,\n                  argEnd\n                )}]`,\n                result.filePath,\n                result.code.substring(0, prefixStart).split(\"\\n\").length - 1,\n                result.code.split(\"\\n\")[\n                  result.code.substring(0, prefixStart).split(\"\\n\").length - 1\n                ],\n                argStart\n              );\n            }\n          } else {\n            argStart = -1;\n            argList = [];\n          }\n        } else {\n          argStart = -1;\n          argList = [];\n        }\n        let nextLineStart = lineEnd + 1;\n        let nextLineEnd = code.indexOf(\"\\n\", nextLineStart);\n        const originalLine = code.substring(nextLineStart, nextLineEnd).trim();\n        let nextLine = originalLine;\n        let isStatic = false;\n        let qualifier: Qualifier = null;\n\n        if (nextLine.startsWith(\"export \")) {\n          nextLine = nextLine.substring(\"export \".length).trim();\n        }\n\n        if (nextLine.startsWith(\"public \")) {\n          qualifier = \"public\";\n          nextLine = nextLine.substring(\"public\".length);\n        } else if (nextLine.startsWith(\"private \")) {\n          qualifier = \"private\";\n          nextLine = nextLine.substring(\"private\".length);\n        } else if (nextLine.startsWith(\"protected \")) {\n          qualifier = \"protected\";\n          nextLine = nextLine.substring(\"protected\".length);\n        }\n\n        nextLine = nextLine.trim();\n        let isClass = nextLine.startsWith(\"class \");\n\n        if (!isClass) {\n          isStatic = nextLine.startsWith(\"static \");\n          if (isStatic) {\n            nextLine.substring(\"static \".length);\n          }\n        }\n\n        if (isClass) {\n          nextLine = nextLine.substring(\"class \".length);\n          // TODO: object pooling\n          await (decoratorFunc as DesignTimeClassFunction<any>)({\n            className: nextLine.substring(0, nextLine.indexOf(\" \")),\n            args: argList,\n            metadata: result,\n          } as DesignTimeClass);\n          return false;\n        } else {\n          // let colon\n          let typeSeparatorIndex = nextLine.indexOf(\":\");\n          let key = nextLine.substring(0, typeSeparatorIndex).trim();\n          let typeName = nextLine.substring(typeSeparatorIndex + 1).trim();\n\n          let semicolonIndex = typeName.indexOf(\";\");\n          if (semicolonIndex > -1) {\n            typeName = typeName.substring(0, semicolonIndex);\n          }\n\n          (result.code as any) = code;\n          // TODO: object pooling\n          const newCode = await (decoratorFunc as DesignTimePropertyDecoratorFunction<any>)(\n            {\n              key,\n              type: typeName,\n              args: argList,\n              isStatic,\n              qualifier,\n              metadata: result,\n            }\n          );\n          if (!newCode && newCode !== \"\") {\n            (result.startIndex as any) = prefixStart;\n            (result.stopIndex as any) = prefixEnd;\n            (result.code as any) = newCode || \"\";\n            return false;\n          }\n\n          (result.startIndex as any) = prefixStart - 1;\n          (result.stopIndex as any) = nextLineEnd - 1;\n          (result.code as any) = newCode || \"\";\n          return true;\n        }\n      };\n\n      decoratorFunctions[i] = processDecorator;\n    }\n    fileMapping[path.basename(moduleName, path.extname(moduleName))] = {\n      decoratorFunctions,\n      decoratorPrefixes,\n    };\n    decoratorPrefixes.forEach((prefix) => allPrefixes.add(prefix));\n  }\n\n  const modulesToCheck = Object.keys(fileMapping);\n  return {\n    process: async (code: string, filePath: string) => {\n      for (let decoratorModuleName of modulesToCheck) {\n        // There's gotta be a faster & less hacky way to do this without a full AST.\n        if (!code.includes(decoratorModuleName)) continue;\n\n        const { decoratorFunctions, decoratorPrefixes } = fileMapping[\n          decoratorModuleName\n        ];\n        let startIndex = -1;\n        let symbolI = code.lastIndexOf(\"@\") - 1;\n        let _prefixI = -1;\n        if (symbolI < -1) return { contents: code, note: null };\n        if (symbolI < 0) symbolI = 0;\n\n        let result = {\n          code,\n          originalSource: code,\n          filePath,\n          startIndex: -1,\n          stopIndex: -1,\n        };\n\n        let prefixI = -1;\n        for (_prefixI = 0; _prefixI < decoratorPrefixes.length; _prefixI++) {\n          result.startIndex = code.indexOf(\n            decoratorPrefixes[_prefixI],\n            symbolI\n          );\n          if (result.startIndex > -1) {\n            prefixI = _prefixI;\n            break;\n          }\n        }\n\n        let prefix = \"\";\n\n        while (prefixI > -1) {\n          prefix = decoratorPrefixes[prefixI];\n          if (result.startIndex > -1) {\n            let _code = result.code;\n            let didChange = false;\n            try {\n              didChange = await decoratorFunctions[prefixI](\n                result.startIndex,\n                result\n              );\n            } catch (exception) {\n              if (exception instanceof ProcessorError) {\n                return {\n                  contents: \"\",\n                  note: exception.note,\n                };\n              } else {\n                throw exception;\n              }\n            }\n\n            if (didChange) {\n              if (result.startIndex > -1 && result.stopIndex > -1) {\n                result.code =\n                  _code.substring(0, result.startIndex) +\n                  result.code +\n                  _code.substring(result.stopIndex);\n              }\n            } else {\n              result.code =\n                _code.substring(0, result.startIndex - 1) +\n                _code.substring(_code.indexOf(\"\\n\", result.startIndex));\n            }\n\n            result.startIndex = result.stopIndex = -1;\n          }\n\n          prefixI = -1;\n          for (_prefixI = 0; _prefixI < decoratorPrefixes.length; _prefixI++) {\n            symbolI = result.code.lastIndexOf(\"@\");\n            if (symbolI === -1) break;\n\n            result.startIndex = result.code.indexOf(\n              decoratorPrefixes[_prefixI],\n              symbolI\n            );\n            if (result.startIndex > -1) {\n              prefixI = _prefixI;\n              break;\n            }\n          }\n        }\n\n        return {\n          contents: result.code,\n          note: null,\n        };\n      }\n    },\n    prefixes: [...allPrefixes],\n  };\n}\n\nfunction onResolveDecorator(args) {\n  return {\n    path: args.path,\n    namespace: \"decorator-stub\",\n  };\n}\n\nfunction onResolveStaticDecorators(args) {\n  return {\n    path: args.path,\n    namespace: \"decky\",\n  };\n}\n\nconst staticDecoratorCode = [property, klass]\n  .map(\n    (stub) =>\n      `/* @__PURE__ */\\nexport function ${stub}(...args){return args;}\\n`\n  )\n  .join(\"\\n\");\n\nfunction onLoadStaticDecorators(args) {\n  return {\n    contents: staticDecoratorCode,\n    loader: \"js\",\n  };\n}\n\nexport function plugin(decorators: DecoratorsMap) {\n  const { prefixes, process } = buildDecoratorProcessor(decorators);\n\n  function isPotentialMatch(content: string) {\n    for (let prefix of prefixes) {\n      if (content.includes(prefix as string)) return true;\n    }\n\n    return false;\n  }\n\n  function onLoadDecoratorStub(args) {\n    const stub = require(args.path).decorators;\n\n    return {\n      contents: Object.keys(stub)\n        .map(\n          (stub) =>\n            `/* @__PURE__ */\\nexport function ${stub}(...args){return args;}\\n`\n        )\n        .join(\"\\n\"),\n      loader: \"ts\",\n    };\n  }\n\n  async function onLoadTSX(args): Promise<OnLoadResult> {\n    let contents: string = await fs.promises.readFile(args.path, \"utf8\");\n    if (!isPotentialMatch(contents))\n      return {\n        contents,\n        loader: \"tsx\",\n      };\n\n    const { note, contents: _contents } =\n      (await process(contents, args.path)) ?? {};\n\n    return {\n      contents: _contents,\n      errors: note\n        ? [{ location: note.location, detail: note.text }]\n        : undefined,\n      loader: \"tsx\",\n    };\n  }\n\n  async function onLoadTS(args): Promise<OnLoadResult> {\n    const contents: string = await fs.promises.readFile(args.path, \"utf8\");\n    if (!isPotentialMatch(contents))\n      return {\n        contents,\n        loader: \"ts\",\n      };\n\n    const { note, contents: _contents } =\n      (await process(contents, args.path)) ?? {};\n\n    return {\n      contents: _contents,\n      errors: note ? [{ location: note.location, text: note.text }] : undefined,\n      loader: \"ts\",\n    };\n  }\n\n  return {\n    name: \"design-time-decorators\",\n    setup(build) {\n      build.onResolve(\n        { filter: /\\.(decorator|dec)\\.(ts)$/ },\n        onResolveDecorator\n      );\n      build.onResolve(\n        { filter: /\\.(decorator|dec)\\.(tsx)$/ },\n        onResolveDecorator\n      );\n      build.onResolve({ filter: /^decky$/ }, onResolveStaticDecorators);\n      build.onLoad(\n        { filter: /^decky$/, namespace: \"decky\" },\n        onLoadStaticDecorators\n      );\n      build.onLoad(\n        { filter: /\\.(decorator|dec)\\.(ts)$/, namespace: \"decorator-stub\" },\n        onLoadDecoratorStub\n      );\n      build.onLoad(\n        { filter: /\\.(decorator|dec)\\.(tsx)$/, namespace: \"decorator-stub\" },\n        onLoadDecoratorStub\n      );\n      build.onLoad({ filter: /\\.(ts)$/ }, onLoadTS);\n      build.onLoad({ filter: /\\.(tsx)$/ }, onLoadTSX);\n    },\n  };\n}\n\ntype OptionalPropertyDescriptor<T> = T extends Exclude<\n  (number | string)[],\n  undefined\n>\n  ? (...args: T) => PropertyDecorator\n  : void;\n\nexport function property<T>(\n  callback: DesignTimePropertyDecoratorFunction<T>\n): OptionalPropertyDescriptor<T> {\n  return {\n    callback,\n    type: DecoratorType.property,\n  } as any;\n}\n\nexport function propertyVoid(\n  callback: DesignTimePropertyDecoratorFunction<never>\n): PropertyDecorator {\n  return {\n    callback,\n    type: DecoratorType.property,\n  } as any;\n}\n\nexport { property as p, propertyVoid as pV };\nexport { klass as c };\n\nexport function klass<T extends any[] = []>(\n  callback: DesignTimeClassFunction<T>\n): (...args: T) => ClassDecorator {\n  return <any | void>{\n    callback,\n    type: DecoratorType.klass,\n  };\n}\n\nexport async function load(\n  decoratorsGlob?: string,\n  additionalConfig?: Partial<BuildOptions>\n) {\n  const entryPoints = await decorators(decoratorsGlob, additionalConfig);\n  const files = {};\n  for (let file of entryPoints) {\n    Object.assign(files, {\n      [file]: require(path.join(\n        process.cwd(),\n        path.dirname(file),\n        path.basename(file).replace(\".ts\", \".js\")\n      )).decorators,\n    });\n  }\n\n  return plugin(files);\n}\n", "import * as esbuild from \"esbuild\";\nimport glob from \"fast-glob\";\n\nexport enum DecoratorType {\n  property = 0,\n  klass = 1,\n}\n\nexport async function decorators(\n  decoratorGlob = \"./**/*.{decorator.ts,dec.ts,decorators.ts,decky.ts}\",\n  additionalConfig: Partial<esbuild.BuildOptions> = {}\n): Promise<string[]> {\n  const entryPoints = !additionalConfig?.entryPoints?.length\n    ? await (glob as any)(decoratorGlob)\n    : additionalConfig.entryPoints;\n\n  await esbuild.build({\n    minify: false,\n    minifySyntax: true,\n    format: \"cjs\",\n    sourcemap: \"both\",\n    outdir: \".\",\n    outbase: \".\",\n    ...additionalConfig,\n    platform: \"node\",\n    entryPoints,\n    bundle: false,\n  });\n\n  return entryPoints;\n}\n"],
  "mappings": ";;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,SAAoB;;;ACDpB,cAAyB,gCACzB,mBAAiB,kCAEL;AAAL,UAAK;AACV,2CAAW,KAAX,YACA,sCAAQ,KAAR;AAAA,GAFU;AAKZ,0BACE,gBAAgB,uDAChB,mBAAkD;AAElD,MAAM,cAAc,AAAC,kBAAkB,aAAa,SAEhD,iBAAiB,cADjB,MAAO,yBAAa;AAGxB,eAAM,AAAQ,cAAM;AAAA,IAClB,QAAQ;AAAA,IACR,cAAc;AAAA,IACd,QAAQ;AAAA,IACR,WAAW;AAAA,IACX,QAAQ;AAAA,IACR,SAAS;AAAA,OACN;AAAA,IACH,UAAU;AAAA,IACV;AAAA,IACA,QAAQ;AAAA,MAGH;AAAA;;;AD1BT,WAAsB;AAHtB,mCA0D6B;AAAA,EAC3B,YACE,SACA,MACA,YACA,UACA;AAEA,UAAM;AACN,SAAK,OAAO;AAAA,MACV,MAAM;AAAA,MACN,UAAU;AAAA,QACR;AAAA,QACA,MAAM;AAAA,QACN;AAAA,QAEA;AAAA;AAAA;AAAA;AAAA;AAOR,iCAAiC;AAC/B,MAAM,cAAc,IACd,cAAc,IAAI;AACxB,WAAS,cAAc;AACrB,QAAM,cAAa,oBAAoB,aACjC,gBAAgB,OAAO,KAAK,aAAY,OAAO,WAC/C,oBAAoB,cAAc,IAAI,CAAC,MAAM,EAAE,aAC/C,qBAAgD,IAAI,MACxD,cAAc,SAEV,iBAAiB,cAAc,IACnC,CAAC,MAAO,YAAW,GAAW;AAGhC,aAAS,IAAI,GAAG,IAAI,cAAc,QAAQ;AACxC,UAAM,MAAM,cAAc,IACpB,SAAS,kBAAkB,IAC3B,SAAS,IAAI,QACb,gBAEyC,eAAe,IAExD,mBAAuC,OAC3C,aACA;AAEA,YAAI,OAAO,OAAO,MACd,YAAY,cAAc,QAC1B,WAAW,WACX,UAAU,KAAK,QAAQ;AAAA,GAAM,cAC7B,SAAS,IACT;AACJ,YAAI,KAAK,gBAAgB;AAEvB,cADA,SAAS,KAAK,QAAQ,KAAK,WACvB,SAAS,IAAI;AACf,gBAAI,SAAS;AACX,oBAAM,IAAI,eACR,iBAAiB,UACjB,OAAO,UACP,OAAO,KAAK,UAAU,GAAG,aAAa,MAAM;AAAA,GAAM,QAClD,OAAO,KAAK,MAAM;AAAA,GAChB,OAAO,KAAK,UAAU,GAAG,aAAa,MAAM;AAAA,GAAM,SAEpD;AAGJ;AACE,wBAAU,KAAK,MACb,MAAM,KAAK,UAAU,UAAU,UAAU;AAAA,qBAEpC;AACP,oBAAM,IAAI,eACR,gBAAgB,mCAAmC,KAAK,UACtD,UACA,YAEF,OAAO,UACP,OAAO,KAAK,UAAU,GAAG,aAAa,MAAM;AAAA,GAAM,SAAS,GAC3D,OAAO,KAAK,MAAM;AAAA,GAChB,OAAO,KAAK,UAAU,GAAG,aAAa,MAAM;AAAA,GAAM,SAAS,IAE7D;AAAA;AAAA;AAIJ,uBAAW,IACX,UAAU;AAAA;AAGZ,qBAAW,IACX,UAAU;AAEZ,YAAI,gBAAgB,UAAU,GAC1B,cAAc,KAAK,QAAQ;AAAA,GAAM,gBAEjC,WADiB,KAAK,UAAU,eAAe,aAAa,QAE5D,WAAW,IACX,YAAuB;AAE3B,QAAI,SAAS,WAAW,cACtB,YAAW,SAAS,UAAU,UAAU,QAAQ,SAGlD,AAAI,SAAS,WAAW,aACtB,aAAY,UACZ,WAAW,SAAS,UAAU,SAAS,WAClC,AAAI,SAAS,WAAW,cAC7B,aAAY,WACZ,WAAW,SAAS,UAAU,UAAU,WAC/B,SAAS,WAAW,iBAC7B,aAAY,aACZ,WAAW,SAAS,UAAU,YAAY,UAG5C,WAAW,SAAS;AACpB,YAAI,UAAU,SAAS,WAAW;AASlC,YAPK,WACH,YAAW,SAAS,WAAW,YAC3B,YACF,SAAS,UAAU,UAAU,UAI7B;AACF,4BAAW,SAAS,UAAU,SAAS,SAEvC,MAAO,cAA+C;AAAA,YACpD,WAAW,SAAS,UAAU,GAAG,SAAS,QAAQ;AAAA,YAClD,MAAM;AAAA,YACN,UAAU;AAAA,cAEL;AACF;AAEL,cAAI,qBAAqB,SAAS,QAAQ,MACtC,OAAM,SAAS,UAAU,GAAG,oBAAoB,QAChD,WAAW,SAAS,UAAU,qBAAqB,GAAG,QAEtD,iBAAiB,SAAS,QAAQ;AACtC,UAAI,iBAAiB,MACnB,YAAW,SAAS,UAAU,GAAG,kBAGlC,OAAO,OAAe;AAEvB,cAAM,UAAU,MAAO,cACrB;AAAA,YACE;AAAA,YACA,MAAM;AAAA,YACN,MAAM;AAAA,YACN;AAAA,YACA;AAAA,YACA,UAAU;AAAA;AAGd,iBAAI,CAAC,WAAW,YAAY,KACzB,QAAO,aAAqB,aAC5B,OAAO,YAAoB,WAC3B,OAAO,OAAe,WAAW,IAC3B,MAGR,QAAO,aAAqB,cAAc,GAC1C,OAAO,YAAoB,cAAc,GACzC,OAAO,OAAe,WAAW,IAC3B;AAAA;AAAA;AAIX,yBAAmB,KAAK;AAAA;AAE1B,gBAAY,AAAK,cAAS,YAAY,AAAK,aAAQ,gBAAgB;AAAA,MACjE;AAAA,MACA;AAAA,OAEF,kBAAkB,QAAQ,CAAC,WAAW,YAAY,IAAI;AAAA;AAGxD,MAAM,iBAAiB,OAAO,KAAK;AACnC,SAAO;AAAA,IACL,SAAS,OAAO,MAAc;AAC5B,eAAS,uBAAuB;AAE9B,YAAI,CAAC,KAAK,SAAS;AAAsB;AAEzC,YAAM,CAAE,oBAAoB,qBAAsB,YAChD,sBAEE,aAAa,IACb,UAAU,KAAK,YAAY,OAAO,GAClC,WAAW;AACf,YAAI,UAAU;AAAI,iBAAO,CAAE,UAAU,MAAM,MAAM;AACjD,QAAI,UAAU,KAAG,WAAU;AAE3B,YAAI,SAAS;AAAA,UACX;AAAA,UACA,gBAAgB;AAAA,UAChB;AAAA,UACA,YAAY;AAAA,UACZ,WAAW;AAAA,WAGT,UAAU;AACd,aAAK,WAAW,GAAG,WAAW,kBAAkB,QAAQ;AAKtD,cAJA,OAAO,aAAa,KAAK,QACvB,kBAAkB,WAClB,UAEE,OAAO,aAAa;AACtB,sBAAU;AACV;AAAA;AAIJ,YAAI,SAAS;AAEb,eAAO,UAAU;AAEf,cADA,SAAS,kBAAkB,UACvB,OAAO,aAAa;AACtB,gBAAI,QAAQ,OAAO,MACf,YAAY;AAChB;AACE,0BAAY,MAAM,mBAAmB,SACnC,OAAO,YACP;AAAA,qBAEK;AACP,kBAAI,qBAAqB;AACvB,uBAAO;AAAA,kBACL,UAAU;AAAA,kBACV,MAAM,UAAU;AAAA;AAGlB,oBAAM;AAAA;AAIV,YAAI,YACE,OAAO,aAAa,MAAM,OAAO,YAAY,MAC/C,QAAO,OACL,MAAM,UAAU,GAAG,OAAO,cAC1B,OAAO,OACP,MAAM,UAAU,OAAO,cAG3B,OAAO,OACL,MAAM,UAAU,GAAG,OAAO,aAAa,KACvC,MAAM,UAAU,MAAM,QAAQ;AAAA,GAAM,OAAO,cAG/C,OAAO,aAAa,OAAO,YAAY;AAAA;AAIzC,eADA,UAAU,IACL,WAAW,GAAG,WAAW,kBAAkB,UAC9C,WAAU,OAAO,KAAK,YAAY,MAC9B,YAAY,KAFsC;AAQtD,gBAJA,OAAO,aAAa,OAAO,KAAK,QAC9B,kBAAkB,WAClB,UAEE,OAAO,aAAa;AACtB,wBAAU;AACV;AAAA;AAAA;AAKN,eAAO;AAAA,UACL,UAAU,OAAO;AAAA,UACjB,MAAM;AAAA;AAAA;AAAA;AAAA,IAIZ,UAAU,CAAC,GAAG;AAAA;AAAA;AAIlB,4BAA4B;AAC1B,SAAO;AAAA,IACL,MAAM,KAAK;AAAA,IACX,WAAW;AAAA;AAAA;AAIf,mCAAmC;AACjC,SAAO;AAAA,IACL,MAAM,KAAK;AAAA,IACX,WAAW;AAAA;AAAA;AAIf,IAAM,sBAAsB,CAAC,UAAU,OACpC,IACC,CAAC,SACC;AAAA,kBAAoC;AAAA,GAEvC,KAAK;AAAA;AAER,gCAAgC;AAC9B,SAAO;AAAA,IACL,UAAU;AAAA,IACV,QAAQ;AAAA;AAAA;AAIL,gBAAgB;AACrB,MAAM,CAAE,UAAU,qBAAY,wBAAwB;AAEtD,4BAA0B;AACxB,aAAS,UAAU;AACjB,UAAI,QAAQ,SAAS;AAAmB,eAAO;AAGjD,WAAO;AAAA;AAGT,+BAA6B;AAC3B,QAAM,OAAO,AAAQ,AAAR,QAAQ,KAAK,MAAM;AAEhC,WAAO;AAAA,MACL,UAAU,OAAO,KAAK,MACnB,IACC,CAAC,UACC;AAAA,kBAAoC;AAAA,GAEvC,KAAK;AAAA;AAAA,MACR,QAAQ;AAAA;AAAA;AAIZ,2BAAyB;AACvB,QAAI,WAAmB,MAAM,AAAG,YAAS,SAAS,KAAK,MAAM;AAC7D,QAAI,CAAC,iBAAiB;AACpB,aAAO;AAAA,QACL;AAAA,QACA,QAAQ;AAAA;AAGZ,QAAM,CAAE,MAAM,UAAU,aACrB,MAAM,SAAQ,UAAU,KAAK,SAAU;AAE1C,WAAO;AAAA,MACL,UAAU;AAAA,MACV,QAAQ,OACJ,CAAC,CAAE,UAAU,KAAK,UAAU,QAAQ,KAAK,SACzC;AAAA,MACJ,QAAQ;AAAA;AAAA;AAIZ,0BAAwB;AACtB,QAAM,WAAmB,MAAM,AAAG,YAAS,SAAS,KAAK,MAAM;AAC/D,QAAI,CAAC,iBAAiB;AACpB,aAAO;AAAA,QACL;AAAA,QACA,QAAQ;AAAA;AAGZ,QAAM,CAAE,MAAM,UAAU,aACrB,MAAM,SAAQ,UAAU,KAAK,SAAU;AAE1C,WAAO;AAAA,MACL,UAAU;AAAA,MACV,QAAQ,OAAO,CAAC,CAAE,UAAU,KAAK,UAAU,MAAM,KAAK,SAAU;AAAA,MAChE,QAAQ;AAAA;AAAA;AAIZ,SAAO;AAAA,IACL,MAAM;AAAA,IACN,MAAM;AACJ,aAAM,UACJ,CAAE,QAAQ,6BACV,qBAEF,OAAM,UACJ,CAAE,QAAQ,8BACV,qBAEF,OAAM,UAAU,CAAE,QAAQ,YAAa,4BACvC,OAAM,OACJ,CAAE,QAAQ,WAAW,WAAW,UAChC,yBAEF,OAAM,OACJ,CAAE,QAAQ,4BAA4B,WAAW,mBACjD,sBAEF,OAAM,OACJ,CAAE,QAAQ,6BAA6B,WAAW,mBAClD,sBAEF,OAAM,OAAO,CAAE,QAAQ,YAAa,WACpC,OAAM,OAAO,CAAE,QAAQ,aAAc;AAAA;AAAA;AAAA;AAYpC,kBACL;AAEA,SAAO;AAAA,IACL;AAAA,IACA,MAAM,cAAc;AAAA;AAAA;AAIjB,sBACL;AAEA,SAAO;AAAA,IACL;AAAA,IACA,MAAM,cAAc;AAAA;AAAA;AAOjB,eACL;AAEA,SAAmB;AAAA,IACjB;AAAA,IACA,MAAM,cAAc;AAAA;AAAA;AAIxB,oBACE,gBACA;AAEA,MAAM,cAAc,MAAM,WAAW,gBAAgB,mBAC/C,QAAQ;AACd,WAAS,QAAQ;AACf,WAAO,OAAO,OAAO;AAAA,OAClB,OAAO,AAAQ,AAAR,QAAQ,AAAK,UACnB,QAAQ,OACR,AAAK,aAAQ,OACb,AAAK,cAAS,MAAM,QAAQ,OAAO,SAClC;AAAA;AAIP,SAAO,OAAO;AAAA;",
  "names": []
}
 |
{ | ||
"name": "decky", | ||
"version": "1.0.5", | ||
"version": "1.0.6", | ||
"keywords": [ | ||
@@ -16,9 +16,10 @@ "typescript", | ||
"experimental-decorators", | ||
"designDecorators", | ||
"design-time-decorators", | ||
"emitDecoratorMetadata", | ||
"types" | ||
], | ||
"types": "./types.d.ts", | ||
"description": "Use experimental decorators with zero runtime overhead.", | ||
"author": "@jarred-sumner", | ||
"module": "./index.mjs", | ||
"module": "index.mjs", | ||
"repository": "https://github.com/jarred-sumner/decky", | ||
@@ -28,5 +29,5 @@ "homepage": "https://github.com/jarred-sumner/decky", | ||
"build": "node build.js", | ||
"types": "tsc --esModuleInterop --downlevelIteration --emitDeclarationOnly --declaration index.ts decorators.ts" | ||
"types": "tsc -p ./tsconfig.build.json" | ||
}, | ||
"main": "./index.js", | ||
"main": "index.js", | ||
"files": [ | ||
@@ -33,0 +34,0 @@ "index.js", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
126998
1222
7
10