cue-ai 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +305 -0
- package/bin/README.md +32 -0
- package/bin/cue +27 -0
- package/bin/medusa-dev +240 -0
- package/bin/soul +4 -0
- package/install.sh +211 -0
- package/package.json +54 -0
- package/plugins/cue/commands/cue-current.md +11 -0
- package/plugins/cue/commands/cue-mcps.md +17 -0
- package/plugins/cue/commands/cue-reload.md +12 -0
- package/plugins/cue/commands/cue-skills.md +19 -0
- package/plugins/cue/commands/cue-switch.md +8 -0
- package/plugins/cue/commands/cue.md +5 -0
- package/plugins/cue/plugin.json +15 -0
- package/profiles/README.md +59 -0
- package/profiles/SCHEMA.md +133 -0
- package/profiles/_active/.gitkeep +0 -0
- package/profiles/_cache/.gitkeep +0 -0
- package/profiles/_cache/README.md +21 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/.runkit_example.js +23 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/LICENSE +22 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/README.md +207 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/2019.d.ts +19 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/2019.js +61 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/2019.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/2020.d.ts +19 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/2020.js +55 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/2020.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/ajv.d.ts +18 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/ajv.js +50 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/ajv.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/code.d.ts +40 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/code.js +156 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/code.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/index.d.ts +79 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/index.js +697 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/scope.d.ts +79 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/scope.js +143 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/codegen/scope.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/errors.d.ts +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/errors.js +123 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/errors.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/index.d.ts +80 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/index.js +242 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/parse.d.ts +4 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/parse.js +350 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/parse.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/serialize.d.ts +4 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/serialize.js +236 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/serialize.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/types.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/types.js +14 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/jtd/types.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/names.d.ts +20 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/names.js +28 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/names.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/ref_error.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/ref_error.js +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/ref_error.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/resolve.d.ts +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/resolve.js +155 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/resolve.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/rules.d.ts +28 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/rules.js +26 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/rules.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/util.d.ts +40 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/util.js +178 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/util.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/applicability.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/applicability.js +19 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/applicability.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/boolSchema.d.ts +4 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/boolSchema.js +50 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/boolSchema.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/dataType.d.ts +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/dataType.js +203 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/dataType.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/defaults.d.ts +2 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/defaults.js +35 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/defaults.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/index.d.ts +42 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/index.js +520 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/keyword.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/keyword.js +124 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/keyword.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/subschema.d.ts +47 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/subschema.js +81 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/compile/validate/subschema.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/core.d.ts +174 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/core.js +618 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/core.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/jtd.d.ts +47 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/jtd.js +72 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/jtd.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/data.json +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/index.d.ts +2 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/index.js +28 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/meta/applicator.json +53 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/meta/content.json +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/meta/core.json +57 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/meta/format.json +14 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/meta/meta-data.json +37 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/meta/validation.json +90 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2019-09/schema.json +39 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/index.d.ts +2 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/index.js +30 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/meta/applicator.json +48 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/meta/content.json +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/meta/core.json +51 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/meta/format-annotation.json +14 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/meta/meta-data.json +37 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/meta/unevaluated.json +15 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/meta/validation.json +90 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-2020-12/schema.json +55 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-draft-06.json +137 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-draft-07.json +151 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/json-schema-secure.json +88 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/jtd-schema.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/jtd-schema.js +118 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/refs/jtd-schema.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/equal.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/equal.js +7 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/equal.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/parseJson.d.ts +18 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/parseJson.js +185 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/parseJson.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/quote.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/quote.js +30 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/quote.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/re2.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/re2.js +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/re2.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/timestamp.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/timestamp.js +42 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/timestamp.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/ucs2length.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/ucs2length.js +24 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/ucs2length.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/uri.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/uri.js +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/uri.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/validation_error.d.ts +7 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/validation_error.js +11 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/runtime/validation_error.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/standalone/index.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/standalone/index.js +90 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/standalone/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/standalone/instance.d.ts +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/standalone/instance.js +35 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/standalone/instance.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/index.d.ts +183 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/index.js +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/json-schema.d.ts +125 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/json-schema.js +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/json-schema.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/jtd-schema.d.ts +174 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/jtd-schema.js +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/types/jtd-schema.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/additionalItems.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/additionalItems.js +49 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/additionalItems.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/additionalProperties.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/additionalProperties.js +106 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/additionalProperties.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/allOf.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/allOf.js +23 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/allOf.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/anyOf.d.ts +4 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/anyOf.js +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/anyOf.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/contains.d.ts +7 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/contains.js +95 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/contains.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/dependencies.d.ts +21 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/dependencies.js +85 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/dependencies.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/dependentSchemas.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/dependentSchemas.js +11 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/dependentSchemas.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/if.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/if.js +66 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/if.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/index.d.ts +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/index.js +44 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/items.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/items.js +52 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/items.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/items2020.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/items2020.js +30 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/items2020.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/not.d.ts +4 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/not.js +26 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/not.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/oneOf.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/oneOf.js +60 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/oneOf.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/patternProperties.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/patternProperties.js +75 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/patternProperties.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/prefixItems.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/prefixItems.js +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/prefixItems.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/properties.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/properties.js +54 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/properties.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/propertyNames.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/propertyNames.js +38 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/propertyNames.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/thenElse.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/thenElse.js +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/applicator/thenElse.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/code.d.ts +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/code.js +131 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/code.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/id.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/id.js +10 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/id.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/index.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/index.js +16 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/ref.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/ref.js +122 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/core/ref.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/discriminator/index.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/discriminator/index.js +104 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/discriminator/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/discriminator/types.d.ts +10 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/discriminator/types.js +9 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/discriminator/types.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/draft2020.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/draft2020.js +23 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/draft2020.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/draft7.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/draft7.js +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/draft7.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/dynamicAnchor.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/dynamicAnchor.js +30 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/dynamicAnchor.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/dynamicRef.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/dynamicRef.js +51 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/dynamicRef.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/index.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/index.js +9 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/recursiveAnchor.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/recursiveAnchor.js +16 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/recursiveAnchor.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/recursiveRef.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/recursiveRef.js +10 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/dynamic/recursiveRef.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/errors.d.ts +9 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/errors.js +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/errors.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/format/format.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/format/format.js +92 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/format/format.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/format/index.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/format/index.js +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/format/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/discriminator.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/discriminator.js +71 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/discriminator.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/elements.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/elements.js +24 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/elements.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/enum.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/enum.js +43 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/enum.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/error.d.ts +9 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/error.js +20 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/error.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/index.d.ts +10 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/index.js +29 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/metadata.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/metadata.js +25 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/metadata.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/nullable.d.ts +4 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/nullable.js +22 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/nullable.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/optionalProperties.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/optionalProperties.js +15 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/optionalProperties.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/properties.d.ts +22 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/properties.js +149 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/properties.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/ref.d.ts +4 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/ref.js +67 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/ref.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/type.d.ts +10 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/type.js +69 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/type.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/union.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/union.js +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/union.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/values.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/values.js +51 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/jtd/values.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/metadata.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/metadata.js +18 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/metadata.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/next.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/next.js +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/next.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/index.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/index.js +7 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/unevaluatedItems.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/unevaluatedItems.js +40 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/unevaluatedItems.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/unevaluatedProperties.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/unevaluatedProperties.js +65 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/unevaluated/unevaluatedProperties.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/const.d.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/const.js +25 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/const.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/dependentRequired.d.ts +5 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/dependentRequired.js +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/dependentRequired.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/enum.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/enum.js +48 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/enum.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/index.d.ts +16 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/index.js +33 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/index.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitContains.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitContains.js +15 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitContains.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitItems.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitItems.js +24 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitItems.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitLength.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitLength.js +27 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitLength.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitNumber.d.ts +11 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitNumber.js +27 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitNumber.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitProperties.d.ts +3 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitProperties.js +24 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/limitProperties.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/multipleOf.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/multipleOf.js +26 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/multipleOf.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/pattern.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/pattern.js +33 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/pattern.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/required.d.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/required.js +79 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/required.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/uniqueItems.d.ts +9 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/uniqueItems.js +64 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/dist/vocabularies/validation/uniqueItems.js.map +1 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/2019.ts +81 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/2020.ts +75 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/ajv.ts +70 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/codegen/code.ts +169 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/codegen/index.ts +852 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/codegen/scope.ts +215 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/errors.ts +184 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/index.ts +324 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/jtd/parse.ts +411 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/jtd/serialize.ts +277 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/jtd/types.ts +16 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/names.ts +27 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/ref_error.ts +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/resolve.ts +149 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/rules.ts +50 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/util.ts +213 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/validate/applicability.ts +22 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/validate/boolSchema.ts +47 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/validate/dataType.ts +230 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/validate/defaults.ts +32 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/validate/index.ts +582 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/validate/keyword.ts +171 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/compile/validate/subschema.ts +135 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/core.ts +892 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/jtd.ts +132 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/data.json +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/index.ts +28 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/meta/applicator.json +53 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/meta/content.json +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/meta/core.json +57 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/meta/format.json +14 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/meta/meta-data.json +37 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/meta/validation.json +90 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2019-09/schema.json +39 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/index.ts +30 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/meta/applicator.json +48 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/meta/content.json +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/meta/core.json +51 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/meta/format-annotation.json +14 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/meta/meta-data.json +37 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/meta/unevaluated.json +15 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/meta/validation.json +90 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-2020-12/schema.json +55 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-draft-06.json +137 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-draft-07.json +151 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/json-schema-secure.json +88 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/refs/jtd-schema.ts +130 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/equal.ts +7 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/parseJson.ts +177 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/quote.ts +31 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/re2.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/timestamp.ts +46 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/ucs2length.ts +20 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/uri.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/runtime/validation_error.ts +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/standalone/index.ts +100 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/standalone/instance.ts +36 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/types/index.ts +244 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/types/json-schema.ts +187 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/types/jtd-schema.ts +273 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/additionalItems.ts +56 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/additionalProperties.ts +118 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/allOf.ts +22 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/anyOf.ts +14 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/contains.ts +109 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/dependencies.ts +112 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/dependentSchemas.ts +11 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/if.ts +80 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/index.ts +53 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/items.ts +59 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/items2020.ts +36 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/not.ts +38 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/oneOf.ts +82 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/patternProperties.ts +91 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/prefixItems.ts +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/properties.ts +57 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/propertyNames.ts +50 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/applicator/thenElse.ts +13 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/code.ts +168 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/core/id.ts +10 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/core/index.ts +16 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/core/ref.ts +129 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/discriminator/index.ts +113 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/discriminator/types.ts +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/draft2020.ts +23 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/draft7.ts +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/dynamic/dynamicAnchor.ts +31 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/dynamic/dynamicRef.ts +51 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/dynamic/index.ts +9 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/dynamic/recursiveAnchor.ts +14 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/dynamic/recursiveRef.ts +10 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/errors.ts +18 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/format/format.ts +120 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/format/index.ts +6 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/discriminator.ts +89 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/elements.ts +32 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/enum.ts +45 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/error.ts +23 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/index.ts +37 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/metadata.ts +24 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/nullable.ts +21 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/optionalProperties.ts +15 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/properties.ts +184 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/ref.ts +76 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/type.ts +75 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/union.ts +12 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/jtd/values.ts +58 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/metadata.ts +17 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/next.ts +8 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/unevaluated/index.ts +7 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/unevaluated/unevaluatedItems.ts +47 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/unevaluated/unevaluatedProperties.ts +85 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/const.ts +28 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/dependentRequired.ts +23 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/enum.ts +54 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/index.ts +49 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/limitContains.ts +16 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/limitItems.ts +26 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/limitLength.ts +30 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/limitNumber.ts +42 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/limitProperties.ts +26 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/multipleOf.ts +34 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/pattern.ts +39 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/required.ts +98 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/lib/vocabularies/validation/uniqueItems.ts +79 -0
- package/profiles/_cache/bun/ajv@8.20.0@@@1/package.json +126 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/LICENSE +21 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/README.md +96 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/es6/index.d.ts +2 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/es6/index.js +72 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/es6/react.d.ts +2 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/es6/react.js +79 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/index.d.ts +4 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/index.js +46 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/package.json +61 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/react.d.ts +2 -0
- package/profiles/_cache/bun/fast-deep-equal@3.1.3@@@1/react.js +53 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/.gitattributes +2 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/.github/dependabot.yml +13 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/.github/workflows/ci.yml +106 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/.github/workflows/lock-threads.yml +19 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/.github/workflows/package-manager-ci.yml +24 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/LICENSE +30 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/README.md +152 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/benchmark/benchmark.mjs +159 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/benchmark/equal.mjs +51 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/benchmark/non-simple-domain.mjs +22 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/benchmark/package.json +17 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/benchmark/string-array-to-hex-stripped.mjs +24 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/benchmark/ws-is-secure.mjs +65 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/eslint.config.js +6 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/index.js +406 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/lib/schemes.js +267 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/lib/utils.js +443 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/package.json +68 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/ajv.test.js +43 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/equal.test.js +117 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/fixtures/uri-js-parse.json +501 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/fixtures/uri-js-serialize.json +120 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/parse.test.js +323 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/resolve.test.js +87 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/rfc-3986.test.js +90 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/security-normalization.test.js +39 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/security.test.js +133 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/serialize.test.js +151 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/uri-js-compatibility.test.js +33 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/uri-js.test.js +912 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/test/util.test.js +38 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/tsconfig.json +9 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/types/index.d.ts +60 -0
- package/profiles/_cache/bun/fast-uri@3.1.2@@@1/types/index.test-d.ts +17 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/.eslintrc.yml +27 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/.github/FUNDING.yml +2 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/.github/workflows/build.yml +28 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/.github/workflows/publish.yml +27 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/LICENSE +21 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/README.md +95 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/index.d.ts +40 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/index.js +93 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/package.json +43 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/spec/.eslintrc.yml +6 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/spec/fixtures/schema.js +125 -0
- package/profiles/_cache/bun/json-schema-traverse@1.0.0@@@1/spec/index.spec.js +171 -0
- package/profiles/_cache/bun/require-from-string@2.0.2@@@1/index.js +34 -0
- package/profiles/_cache/bun/require-from-string@2.0.2@@@1/license +21 -0
- package/profiles/_cache/bun/require-from-string@2.0.2@@@1/package.json +28 -0
- package/profiles/_cache/bun/require-from-string@2.0.2@@@1/readme.md +56 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/LICENSE +13 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/README.md +172 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/bin.mjs +11 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/compose-collection.js +88 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/compose-doc.js +43 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/compose-node.js +109 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/compose-scalar.js +86 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/composer.js +219 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/resolve-block-map.js +115 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/resolve-block-scalar.js +198 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/resolve-block-seq.js +49 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/resolve-end.js +37 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/resolve-flow-collection.js +207 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/resolve-flow-scalar.js +225 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/resolve-props.js +146 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/util-contains-newline.js +34 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/util-empty-scalar-position.js +26 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/util-flow-indent-check.js +15 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/compose/util-map-includes.js +13 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/doc/Document.js +335 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/doc/anchors.js +71 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/doc/applyReviver.js +55 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/doc/createNode.js +88 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/doc/directives.js +176 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/errors.js +57 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/index.js +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/log.js +11 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/Alias.js +116 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/Collection.js +147 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/Node.js +38 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/Pair.js +36 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/Scalar.js +24 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/YAMLMap.js +144 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/YAMLSeq.js +113 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/addPairToJSMap.js +63 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/identity.js +36 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/nodes/toJS.js +37 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/parse/cst-scalar.js +214 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/parse/cst-stringify.js +61 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/parse/cst-visit.js +97 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/parse/cst.js +98 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/parse/lexer.js +721 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/parse/line-counter.js +39 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/parse/parser.js +975 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/public-api.js +102 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/Schema.js +37 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/common/map.js +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/common/null.js +15 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/common/seq.js +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/common/string.js +14 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/core/bool.js +19 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/core/float.js +43 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/core/int.js +38 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/core/schema.js +23 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/json/schema.js +62 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/tags.js +96 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/binary.js +58 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/bool.js +26 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/float.js +46 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/int.js +71 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/merge.js +67 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/omap.js +74 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/pairs.js +78 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/schema.js +39 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/set.js +93 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/schema/yaml-1.1/timestamp.js +101 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/foldFlowLines.js +146 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/stringify.js +129 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/stringifyCollection.js +153 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/stringifyComment.js +20 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/stringifyDocument.js +85 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/stringifyNumber.js +25 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/stringifyPair.js +150 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/stringify/stringifyString.js +336 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/util.js +11 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/dist/visit.js +233 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/index.js +5 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/browser/package.json +3 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/cli.d.ts +8 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/cli.mjs +201 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-collection.d.ts +11 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-collection.js +90 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-doc.d.ts +7 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-doc.js +45 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-node.d.ts +29 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-node.js +112 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-scalar.d.ts +5 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/compose-scalar.js +88 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/composer.d.ts +63 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/composer.js +224 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-block-map.d.ts +6 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-block-map.js +117 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-block-scalar.d.ts +11 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-block-scalar.js +200 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-block-seq.d.ts +6 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-block-seq.js +51 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-end.d.ts +6 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-end.js +39 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-flow-collection.d.ts +7 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-flow-collection.js +209 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-flow-scalar.d.ts +10 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-flow-scalar.js +227 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-props.d.ts +23 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/resolve-props.js +148 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-contains-newline.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-contains-newline.js +36 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-empty-scalar-position.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-empty-scalar-position.js +28 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-flow-indent-check.d.ts +3 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-flow-indent-check.js +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-map-includes.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/compose/util-map-includes.js +15 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/Document.d.ts +141 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/Document.js +337 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/anchors.d.ts +24 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/anchors.js +76 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/applyReviver.d.ts +9 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/applyReviver.js +57 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/createNode.d.ts +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/createNode.js +90 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/directives.d.ts +49 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/doc/directives.js +178 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/errors.d.ts +21 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/errors.js +62 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/index.d.ts +25 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/index.js +50 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/log.d.ts +3 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/log.js +19 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Alias.d.ts +29 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Alias.js +118 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Collection.d.ts +73 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Collection.js +151 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Node.d.ts +53 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Node.js +40 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Pair.d.ts +22 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Pair.js +39 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Scalar.d.ts +47 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/Scalar.js +27 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/YAMLMap.d.ts +53 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/YAMLMap.js +147 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/YAMLSeq.d.ts +60 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/YAMLSeq.js +115 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/addPairToJSMap.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/addPairToJSMap.js +65 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/identity.d.ts +23 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/identity.js +53 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/toJS.d.ts +29 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/nodes/toJS.js +39 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/options.d.ts +350 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst-scalar.d.ts +64 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst-scalar.js +218 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst-stringify.d.ts +8 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst-stringify.js +63 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst-visit.d.ts +39 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst-visit.js +99 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst.d.ts +109 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/cst.js +112 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/lexer.d.ts +87 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/lexer.js +723 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/line-counter.d.ts +22 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/line-counter.js +41 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/parser.d.ts +84 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/parse/parser.js +980 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/public-api.d.ts +44 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/public-api.js +107 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/Schema.d.ts +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/Schema.js +39 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/map.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/map.js +19 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/null.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/null.js +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/seq.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/seq.js +19 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/string.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/common/string.js +16 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/bool.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/bool.js +21 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/float.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/float.js +47 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/int.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/int.js +42 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/schema.d.ts +1 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/core/schema.js +25 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/json/schema.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/json/schema.js +64 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/json-schema.d.ts +69 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/tags.d.ts +48 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/tags.js +99 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/types.d.ts +92 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/binary.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/binary.js +70 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/bool.d.ts +7 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/bool.js +29 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/float.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/float.js +50 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/int.d.ts +5 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/int.js +76 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/merge.d.ts +9 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/merge.js +71 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/omap.d.ts +22 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/omap.js +77 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/pairs.d.ts +10 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/pairs.js +82 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/schema.d.ts +1 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/schema.js +41 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/set.d.ts +28 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/set.js +96 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/timestamp.d.ts +6 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/schema/yaml-1.1/timestamp.js +105 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/foldFlowLines.d.ts +34 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/foldFlowLines.js +151 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringify.d.ts +21 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringify.js +132 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyCollection.d.ts +17 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyCollection.js +155 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyComment.d.ts +10 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyComment.js +24 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyDocument.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyDocument.js +87 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyNumber.d.ts +2 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyNumber.js +27 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyPair.d.ts +3 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyPair.js +152 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyString.d.ts +9 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/stringify/stringifyString.js +338 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/test-events.d.ts +4 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/test-events.js +134 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/util.d.ts +16 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/util.js +28 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/visit.d.ts +102 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/dist/visit.js +236 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/package.json +97 -0
- package/profiles/_cache/bun/yaml@2.9.0@@@1/util.js +2 -0
- package/profiles/_examples/inherits.yaml +27 -0
- package/profiles/_examples/minimal.yaml +11 -0
- package/profiles/_types.ts +103 -0
- package/profiles/backend/README.md +34 -0
- package/profiles/backend/profile.yaml +19 -0
- package/profiles/caveman-quick/README.md +29 -0
- package/profiles/caveman-quick/profile.yaml +14 -0
- package/profiles/coolify/logo.png +0 -0
- package/profiles/coolify/profile.yaml +16 -0
- package/profiles/core/README.md +21 -0
- package/profiles/core/profile.yaml +15 -0
- package/profiles/creative-media/README.md +36 -0
- package/profiles/creative-media/profile.yaml +21 -0
- package/profiles/cybersecurity/profile.yaml +761 -0
- package/profiles/docs-writer/README.md +32 -0
- package/profiles/docs-writer/profile.yaml +17 -0
- package/profiles/fleet-control/README.md +36 -0
- package/profiles/fleet-control/profile.yaml +21 -0
- package/profiles/frontend/README.md +32 -0
- package/profiles/frontend/profile.yaml +17 -0
- package/profiles/full/README.md +31 -0
- package/profiles/full/profile.yaml +23 -0
- package/profiles/hostinger/logo.png +0 -0
- package/profiles/hostinger/profile.yaml +15 -0
- package/profiles/marketing/README.md +20 -0
- package/profiles/marketing/profile.yaml +12 -0
- package/profiles/medusa-dev/README.md +36 -0
- package/profiles/medusa-dev/profile.yaml +21 -0
- package/profiles/nvidia/logo.png +0 -0
- package/profiles/nvidia/profile.yaml +20 -0
- package/profiles/readme-writer-svg/profile.yaml +13 -0
- package/profiles/research/README.md +34 -0
- package/profiles/research/profile.yaml +19 -0
- package/profiles/schema.json +152 -0
- package/resources/claude-md/README.md +33 -0
- package/resources/claude-md/_always/karpathy-guidelines.md +63 -0
- package/resources/claude-plugins-official/.claude-plugin/marketplace.json +2701 -0
- package/resources/claude-plugins-official/.github/policy/prompt.md +99 -0
- package/resources/claude-plugins-official/.github/policy/schema.json +52 -0
- package/resources/claude-plugins-official/.github/scripts/discover_bumps.py +229 -0
- package/resources/claude-plugins-official/.github/scripts/validate-frontmatter.ts +277 -0
- package/resources/claude-plugins-official/.github/workflows/bump-plugin-shas.yml +69 -0
- package/resources/claude-plugins-official/.github/workflows/check-mcp-urls.yml +129 -0
- package/resources/claude-plugins-official/.github/workflows/close-external-prs.yml +47 -0
- package/resources/claude-plugins-official/.github/workflows/revert-failed-bumps.yml +284 -0
- package/resources/claude-plugins-official/.github/workflows/scan-plugins.yml +380 -0
- package/resources/claude-plugins-official/.github/workflows/validate-frontmatter.yml +42 -0
- package/resources/claude-plugins-official/.github/workflows/validate-plugins.yml +34 -0
- package/resources/claude-plugins-official/README.md +51 -0
- package/resources/claude-plugins-official/external_plugins/asana/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/asana/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/context7/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/context7/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/discord/.claude-plugin/plugin.json +11 -0
- package/resources/claude-plugins-official/external_plugins/discord/.mcp.json +8 -0
- package/resources/claude-plugins-official/external_plugins/discord/ACCESS.md +143 -0
- package/resources/claude-plugins-official/external_plugins/discord/LICENSE +202 -0
- package/resources/claude-plugins-official/external_plugins/discord/README.md +112 -0
- package/resources/claude-plugins-official/external_plugins/discord/bun.lock +244 -0
- package/resources/claude-plugins-official/external_plugins/discord/package.json +14 -0
- package/resources/claude-plugins-official/external_plugins/discord/server.ts +900 -0
- package/resources/claude-plugins-official/external_plugins/discord/skills/access/SKILL.md +137 -0
- package/resources/claude-plugins-official/external_plugins/discord/skills/configure/SKILL.md +99 -0
- package/resources/claude-plugins-official/external_plugins/fakechat/.claude-plugin/plugin.json +13 -0
- package/resources/claude-plugins-official/external_plugins/fakechat/.mcp.json +8 -0
- package/resources/claude-plugins-official/external_plugins/fakechat/LICENSE +202 -0
- package/resources/claude-plugins-official/external_plugins/fakechat/README.md +47 -0
- package/resources/claude-plugins-official/external_plugins/fakechat/bun.lock +206 -0
- package/resources/claude-plugins-official/external_plugins/fakechat/package.json +16 -0
- package/resources/claude-plugins-official/external_plugins/fakechat/server.ts +295 -0
- package/resources/claude-plugins-official/external_plugins/firebase/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/firebase/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/github/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/github/.mcp.json +9 -0
- package/resources/claude-plugins-official/external_plugins/gitlab/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/gitlab/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/greptile/.claude-plugin/plugin.json +10 -0
- package/resources/claude-plugins-official/external_plugins/greptile/.mcp.json +9 -0
- package/resources/claude-plugins-official/external_plugins/greptile/README.md +57 -0
- package/resources/claude-plugins-official/external_plugins/imessage/.claude-plugin/plugin.json +11 -0
- package/resources/claude-plugins-official/external_plugins/imessage/.mcp.json +8 -0
- package/resources/claude-plugins-official/external_plugins/imessage/ACCESS.md +142 -0
- package/resources/claude-plugins-official/external_plugins/imessage/LICENSE +202 -0
- package/resources/claude-plugins-official/external_plugins/imessage/README.md +84 -0
- package/resources/claude-plugins-official/external_plugins/imessage/bun.lock +207 -0
- package/resources/claude-plugins-official/external_plugins/imessage/package.json +17 -0
- package/resources/claude-plugins-official/external_plugins/imessage/server.ts +875 -0
- package/resources/claude-plugins-official/external_plugins/imessage/skills/access/SKILL.md +140 -0
- package/resources/claude-plugins-official/external_plugins/imessage/skills/configure/SKILL.md +82 -0
- package/resources/claude-plugins-official/external_plugins/laravel-boost/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/laravel-boost/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/linear/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/linear/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/playwright/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/playwright/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/serena/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/serena/.mcp.json +6 -0
- package/resources/claude-plugins-official/external_plugins/telegram/.claude-plugin/plugin.json +11 -0
- package/resources/claude-plugins-official/external_plugins/telegram/.mcp.json +8 -0
- package/resources/claude-plugins-official/external_plugins/telegram/ACCESS.md +147 -0
- package/resources/claude-plugins-official/external_plugins/telegram/LICENSE +202 -0
- package/resources/claude-plugins-official/external_plugins/telegram/README.md +99 -0
- package/resources/claude-plugins-official/external_plugins/telegram/bun.lock +212 -0
- package/resources/claude-plugins-official/external_plugins/telegram/package.json +14 -0
- package/resources/claude-plugins-official/external_plugins/telegram/server.ts +1038 -0
- package/resources/claude-plugins-official/external_plugins/telegram/skills/access/SKILL.md +136 -0
- package/resources/claude-plugins-official/external_plugins/telegram/skills/configure/SKILL.md +96 -0
- package/resources/claude-plugins-official/external_plugins/terraform/.claude-plugin/plugin.json +7 -0
- package/resources/claude-plugins-official/external_plugins/terraform/.mcp.json +12 -0
- package/resources/claude-plugins-official/plugins/agent-sdk-dev/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/agent-sdk-dev/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/agent-sdk-dev/README.md +208 -0
- package/resources/claude-plugins-official/plugins/agent-sdk-dev/agents/agent-sdk-verifier-py.md +140 -0
- package/resources/claude-plugins-official/plugins/agent-sdk-dev/agents/agent-sdk-verifier-ts.md +145 -0
- package/resources/claude-plugins-official/plugins/agent-sdk-dev/commands/new-sdk-app.md +176 -0
- package/resources/claude-plugins-official/plugins/clangd-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/clangd-lsp/README.md +36 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/README.md +29 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/automation-recommender-example.png +0 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/skills/claude-automation-recommender/SKILL.md +288 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/skills/claude-automation-recommender/references/hooks-patterns.md +226 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/skills/claude-automation-recommender/references/mcp-servers.md +263 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/skills/claude-automation-recommender/references/plugins-reference.md +98 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/skills/claude-automation-recommender/references/skills-reference.md +408 -0
- package/resources/claude-plugins-official/plugins/claude-code-setup/skills/claude-automation-recommender/references/subagent-templates.md +181 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/README.md +40 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/claude-md-improver-example.png +0 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/commands/revise-claude-md.md +54 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/revise-claude-md-example.png +0 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/skills/claude-md-improver/SKILL.md +179 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/skills/claude-md-improver/references/quality-criteria.md +109 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/skills/claude-md-improver/references/templates.md +253 -0
- package/resources/claude-plugins-official/plugins/claude-md-management/skills/claude-md-improver/references/update-guidelines.md +150 -0
- package/resources/claude-plugins-official/plugins/code-modernization/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/code-modernization/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/code-modernization/README.md +119 -0
- package/resources/claude-plugins-official/plugins/code-modernization/agents/architecture-critic.md +36 -0
- package/resources/claude-plugins-official/plugins/code-modernization/agents/business-rules-extractor.md +46 -0
- package/resources/claude-plugins-official/plugins/code-modernization/agents/legacy-analyst.md +39 -0
- package/resources/claude-plugins-official/plugins/code-modernization/agents/security-auditor.md +56 -0
- package/resources/claude-plugins-official/plugins/code-modernization/agents/test-engineer.md +36 -0
- package/resources/claude-plugins-official/plugins/code-modernization/commands/modernize-assess.md +161 -0
- package/resources/claude-plugins-official/plugins/code-modernization/commands/modernize-brief.md +65 -0
- package/resources/claude-plugins-official/plugins/code-modernization/commands/modernize-extract-rules.md +76 -0
- package/resources/claude-plugins-official/plugins/code-modernization/commands/modernize-harden.md +64 -0
- package/resources/claude-plugins-official/plugins/code-modernization/commands/modernize-map.md +104 -0
- package/resources/claude-plugins-official/plugins/code-modernization/commands/modernize-reimagine.md +83 -0
- package/resources/claude-plugins-official/plugins/code-modernization/commands/modernize-transform.md +78 -0
- package/resources/claude-plugins-official/plugins/code-review/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/code-review/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/code-review/README.md +246 -0
- package/resources/claude-plugins-official/plugins/code-review/commands/code-review.md +92 -0
- package/resources/claude-plugins-official/plugins/code-simplifier/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/code-simplifier/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/code-simplifier/agents/code-simplifier.md +52 -0
- package/resources/claude-plugins-official/plugins/commit-commands/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/commit-commands/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/commit-commands/README.md +225 -0
- package/resources/claude-plugins-official/plugins/commit-commands/commands/clean_gone.md +53 -0
- package/resources/claude-plugins-official/plugins/commit-commands/commands/commit-push-pr.md +20 -0
- package/resources/claude-plugins-official/plugins/commit-commands/commands/commit.md +17 -0
- package/resources/claude-plugins-official/plugins/csharp-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/csharp-lsp/README.md +25 -0
- package/resources/claude-plugins-official/plugins/cwc-makers/.claude-plugin/plugin.json +21 -0
- package/resources/claude-plugins-official/plugins/cwc-makers/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/cwc-makers/README.md +38 -0
- package/resources/claude-plugins-official/plugins/cwc-makers/commands/maker-setup.md +15 -0
- package/resources/claude-plugins-official/plugins/cwc-makers/skills/cardputer-buddy/SKILL.md +46 -0
- package/resources/claude-plugins-official/plugins/cwc-makers/skills/m5-onboard/SKILL.md +185 -0
- package/resources/claude-plugins-official/plugins/example-plugin/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/example-plugin/.mcp.json +6 -0
- package/resources/claude-plugins-official/plugins/example-plugin/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/example-plugin/README.md +69 -0
- package/resources/claude-plugins-official/plugins/example-plugin/commands/example-command.md +39 -0
- package/resources/claude-plugins-official/plugins/example-plugin/skills/example-command/SKILL.md +39 -0
- package/resources/claude-plugins-official/plugins/example-plugin/skills/example-skill/SKILL.md +84 -0
- package/resources/claude-plugins-official/plugins/explanatory-output-style/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/explanatory-output-style/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/explanatory-output-style/README.md +72 -0
- package/resources/claude-plugins-official/plugins/explanatory-output-style/hooks/hooks.json +15 -0
- package/resources/claude-plugins-official/plugins/explanatory-output-style/hooks-handlers/session-start.sh +15 -0
- package/resources/claude-plugins-official/plugins/feature-dev/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/feature-dev/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/feature-dev/README.md +412 -0
- package/resources/claude-plugins-official/plugins/feature-dev/agents/code-architect.md +34 -0
- package/resources/claude-plugins-official/plugins/feature-dev/agents/code-explorer.md +51 -0
- package/resources/claude-plugins-official/plugins/feature-dev/agents/code-reviewer.md +46 -0
- package/resources/claude-plugins-official/plugins/feature-dev/commands/feature-dev.md +125 -0
- package/resources/claude-plugins-official/plugins/frontend-design/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/frontend-design/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/frontend-design/README.md +31 -0
- package/resources/claude-plugins-official/plugins/frontend-design/skills/frontend-design/SKILL.md +42 -0
- package/resources/claude-plugins-official/plugins/gopls-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/gopls-lsp/README.md +20 -0
- package/resources/claude-plugins-official/plugins/hookify/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/hookify/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/hookify/README.md +340 -0
- package/resources/claude-plugins-official/plugins/hookify/agents/conversation-analyzer.md +185 -0
- package/resources/claude-plugins-official/plugins/hookify/commands/configure.md +128 -0
- package/resources/claude-plugins-official/plugins/hookify/commands/help.md +175 -0
- package/resources/claude-plugins-official/plugins/hookify/commands/hookify.md +231 -0
- package/resources/claude-plugins-official/plugins/hookify/commands/list.md +82 -0
- package/resources/claude-plugins-official/plugins/hookify/core/__init__.py +0 -0
- package/resources/claude-plugins-official/plugins/hookify/core/config_loader.py +297 -0
- package/resources/claude-plugins-official/plugins/hookify/core/rule_engine.py +313 -0
- package/resources/claude-plugins-official/plugins/hookify/examples/console-log-warning.local.md +14 -0
- package/resources/claude-plugins-official/plugins/hookify/examples/dangerous-rm.local.md +14 -0
- package/resources/claude-plugins-official/plugins/hookify/examples/require-tests-stop.local.md +22 -0
- package/resources/claude-plugins-official/plugins/hookify/examples/sensitive-files-warning.local.md +18 -0
- package/resources/claude-plugins-official/plugins/hookify/hooks/__init__.py +0 -0
- package/resources/claude-plugins-official/plugins/hookify/hooks/hooks.json +49 -0
- package/resources/claude-plugins-official/plugins/hookify/hooks/posttooluse.py +62 -0
- package/resources/claude-plugins-official/plugins/hookify/hooks/pretooluse.py +66 -0
- package/resources/claude-plugins-official/plugins/hookify/hooks/stop.py +55 -0
- package/resources/claude-plugins-official/plugins/hookify/hooks/userpromptsubmit.py +54 -0
- package/resources/claude-plugins-official/plugins/hookify/matchers/__init__.py +0 -0
- package/resources/claude-plugins-official/plugins/hookify/skills/writing-rules/SKILL.md +374 -0
- package/resources/claude-plugins-official/plugins/hookify/utils/__init__.py +0 -0
- package/resources/claude-plugins-official/plugins/jdtls-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/jdtls-lsp/README.md +33 -0
- package/resources/claude-plugins-official/plugins/kotlin-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/kotlin-lsp/README.md +16 -0
- package/resources/claude-plugins-official/plugins/learning-output-style/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/learning-output-style/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/learning-output-style/README.md +93 -0
- package/resources/claude-plugins-official/plugins/learning-output-style/hooks/hooks.json +15 -0
- package/resources/claude-plugins-official/plugins/learning-output-style/hooks-handlers/session-start.sh +15 -0
- package/resources/claude-plugins-official/plugins/lua-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/lua-lsp/README.md +32 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/README.md +40 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/SKILL.md +411 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/evals/trigger_eval.json +23 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/references/adversarial_prompts.md +293 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/references/attempt_agent.md +63 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/references/known_constructions.md +46 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/references/model_tier_defaults.md +66 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/references/presentation_prompts.md +153 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/references/solver_heuristics.md +135 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/references/verifier_patterns.md +206 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/scripts/check_latex.sh +4 -0
- package/resources/claude-plugins-official/plugins/math-olympiad/skills/math-olympiad/scripts/compile_pdf.sh +54 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/README.md +32 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-app/SKILL.md +392 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-app/references/abuse-protection.md +60 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-app/references/apps-sdk-messages.md +227 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-app/references/directory-checklist.md +18 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-app/references/iframe-sandbox.md +164 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-app/references/payload-budgeting.md +54 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-app/references/widget-templates.md +249 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/SKILL.md +221 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/auth.md +108 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/deploy-cloudflare-workers.md +106 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/elicitation.md +129 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/remote-http-scaffold.md +211 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/resources-and-prompts.md +122 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/server-capabilities.md +164 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/tool-design.md +189 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcp-server/references/versions.md +25 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcpb/SKILL.md +199 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcpb/references/local-security.md +149 -0
- package/resources/claude-plugins-official/plugins/mcp-server-dev/skills/build-mcpb/references/manifest-schema.md +156 -0
- package/resources/claude-plugins-official/plugins/mcp-tunnels/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/mcp-tunnels/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/mcp-tunnels/README.md +122 -0
- package/resources/claude-plugins-official/plugins/mcp-tunnels/commands/create-docker-mcp-tunnel.md +369 -0
- package/resources/claude-plugins-official/plugins/php-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/php-lsp/README.md +24 -0
- package/resources/claude-plugins-official/plugins/playground/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/playground/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/playground/README.md +28 -0
- package/resources/claude-plugins-official/plugins/playground/skills/playground/SKILL.md +76 -0
- package/resources/claude-plugins-official/plugins/playground/skills/playground/templates/code-map.md +158 -0
- package/resources/claude-plugins-official/plugins/playground/skills/playground/templates/concept-map.md +73 -0
- package/resources/claude-plugins-official/plugins/playground/skills/playground/templates/data-explorer.md +67 -0
- package/resources/claude-plugins-official/plugins/playground/skills/playground/templates/design-playground.md +67 -0
- package/resources/claude-plugins-official/plugins/playground/skills/playground/templates/diff-review.md +179 -0
- package/resources/claude-plugins-official/plugins/playground/skills/playground/templates/document-critique.md +171 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/README.md +402 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/agents/agent-creator.md +176 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/agents/plugin-validator.md +184 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/agents/skill-reviewer.md +184 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/commands/create-plugin.md +449 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/agent-development/SKILL.md +401 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/agent-development/examples/agent-creation-prompt.md +224 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/agent-development/examples/complete-agent-examples.md +357 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/agent-development/references/agent-creation-system-prompt.md +189 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/agent-development/references/system-prompt-design.md +411 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/agent-development/references/triggering-examples.md +217 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/agent-development/scripts/validate-agent.sh +217 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/README.md +272 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/SKILL.md +884 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/examples/plugin-commands.md +557 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/examples/simple-commands.md +504 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/references/advanced-workflows.md +722 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/references/documentation-patterns.md +739 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/references/frontmatter-reference.md +463 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/references/interactive-commands.md +920 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/references/marketplace-considerations.md +904 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/references/plugin-features-reference.md +609 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/command-development/references/testing-strategies.md +702 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/SKILL.md +712 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/examples/load-context.sh +55 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/examples/validate-bash.sh +43 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/examples/validate-write.sh +38 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/references/advanced.md +479 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/references/migration.md +369 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/references/patterns.md +346 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/scripts/README.md +164 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/scripts/hook-linter.sh +153 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/scripts/test-hook.sh +252 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/hook-development/scripts/validate-hook-schema.sh +159 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/mcp-integration/SKILL.md +554 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/mcp-integration/examples/http-server.json +20 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/mcp-integration/examples/sse-server.json +19 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/mcp-integration/examples/stdio-server.json +26 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/mcp-integration/references/authentication.md +549 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/mcp-integration/references/server-types.md +536 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/mcp-integration/references/tool-usage.md +538 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/SKILL.md +544 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/examples/create-settings-command.md +98 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/examples/example-settings.md +159 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/examples/read-settings-hook.sh +65 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/references/parsing-techniques.md +549 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/references/real-world-examples.md +395 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/scripts/parse-frontmatter.sh +59 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-settings/scripts/validate-settings.sh +101 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-structure/README.md +109 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-structure/SKILL.md +476 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-structure/examples/advanced-plugin.md +765 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-structure/examples/minimal-plugin.md +83 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-structure/examples/standard-plugin.md +587 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-structure/references/component-patterns.md +567 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/plugin-structure/references/manifest-reference.md +552 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/skill-development/SKILL.md +637 -0
- package/resources/claude-plugins-official/plugins/plugin-dev/skills/skill-development/references/skill-creator-original.md +209 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/README.md +313 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/agents/code-reviewer.md +56 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/agents/code-simplifier.md +88 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/agents/comment-analyzer.md +79 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/agents/pr-test-analyzer.md +78 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/agents/silent-failure-hunter.md +130 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/agents/type-design-analyzer.md +118 -0
- package/resources/claude-plugins-official/plugins/pr-review-toolkit/commands/review-pr.md +189 -0
- package/resources/claude-plugins-official/plugins/pyright-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/pyright-lsp/README.md +31 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/.claude-plugin/plugin.json +9 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/README.md +197 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/commands/cancel-ralph.md +18 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/commands/help.md +126 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/commands/ralph-loop.md +18 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/hooks/hooks.json +15 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/hooks/stop-hook.sh +191 -0
- package/resources/claude-plugins-official/plugins/ralph-loop/scripts/setup-ralph-loop.sh +204 -0
- package/resources/claude-plugins-official/plugins/ruby-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/ruby-lsp/README.md +31 -0
- package/resources/claude-plugins-official/plugins/rust-analyzer-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/rust-analyzer-lsp/README.md +34 -0
- package/resources/claude-plugins-official/plugins/security-guidance/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/security-guidance/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/security-guidance/hooks/hooks.json +16 -0
- package/resources/claude-plugins-official/plugins/security-guidance/hooks/security_reminder_hook.py +280 -0
- package/resources/claude-plugins-official/plugins/session-report/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/session-report/skills/session-report/SKILL.md +42 -0
- package/resources/claude-plugins-official/plugins/session-report/skills/session-report/analyze-sessions.mjs +875 -0
- package/resources/claude-plugins-official/plugins/session-report/skills/session-report/template.html +569 -0
- package/resources/claude-plugins-official/plugins/skill-creator/.claude-plugin/plugin.json +8 -0
- package/resources/claude-plugins-official/plugins/skill-creator/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/skill-creator/README.md +3 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/LICENSE.txt +202 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/SKILL.md +485 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/agents/analyzer.md +274 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/agents/comparator.md +202 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/agents/grader.md +223 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/assets/eval_review.html +146 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/eval-viewer/generate_review.py +471 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/eval-viewer/viewer.html +1325 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/references/schemas.md +430 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/__init__.py +0 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/generate_report.py +326 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/improve_description.py +247 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/package_skill.py +136 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/quick_validate.py +103 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/run_eval.py +310 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/run_loop.py +328 -0
- package/resources/claude-plugins-official/plugins/skill-creator/skills/skill-creator/scripts/utils.py +47 -0
- package/resources/claude-plugins-official/plugins/swift-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/swift-lsp/README.md +25 -0
- package/resources/claude-plugins-official/plugins/typescript-lsp/LICENSE +202 -0
- package/resources/claude-plugins-official/plugins/typescript-lsp/README.md +24 -0
- package/resources/colony-profiles.yaml +20 -0
- package/resources/icons/ansible.png +0 -0
- package/resources/icons/aws.png +0 -0
- package/resources/icons/azure.png +0 -0
- package/resources/icons/colony.png +0 -0
- package/resources/icons/coolify-brand.png +0 -0
- package/resources/icons/docker.png +0 -0
- package/resources/icons/elastic.png +0 -0
- package/resources/icons/frida.png +0 -0
- package/resources/icons/gcloud.png +0 -0
- package/resources/icons/generate-icons.py +232 -0
- package/resources/icons/ghidra.png +0 -0
- package/resources/icons/github.png +0 -0
- package/resources/icons/golang.png +0 -0
- package/resources/icons/hashicorp.png +0 -0
- package/resources/icons/higgsfield.png +0 -0
- package/resources/icons/kubernetes.png +0 -0
- package/resources/icons/medusa.png +0 -0
- package/resources/icons/nmap.png +0 -0
- package/resources/icons/nodejs.png +0 -0
- package/resources/icons/obsidian.png +0 -0
- package/resources/icons/openai.png +0 -0
- package/resources/icons/owasp.png +0 -0
- package/resources/icons/polymarket.png +0 -0
- package/resources/icons/python.png +0 -0
- package/resources/icons/rust.png +0 -0
- package/resources/icons/splunk.png +0 -0
- package/resources/icons/stripe.png +0 -0
- package/resources/icons/wireshark.png +0 -0
- package/resources/mcps/README.md +181 -0
- package/resources/mcps/configs/claude.sanitized.json +17 -0
- package/resources/mcps/configs/claude_runtime.projects.sanitized.json +32 -0
- package/resources/mcps/configs/claude_runtime.sanitized.json +117 -0
- package/resources/mcps/configs/codex.sanitized.json +86 -0
- package/resources/mcps/configs/mcp-skill-map.json +399 -0
- package/resources/mcps/configs/mcp-skill-rules.json +341 -0
- package/resources/mcps/configs/vscode.sanitized.json +29 -0
- package/resources/mcps/docs/health.md +20 -0
- package/resources/mcps/docs/inventory.md +95 -0
- package/resources/mcps/docs/mcp-skill-map.md +27 -0
- package/resources/mcps/mcps/codegraph/skills.md +7 -0
- package/resources/mcps/mcps/colony/README.md +87 -0
- package/resources/mcps/mcps/colony/skills.md +25 -0
- package/resources/mcps/mcps/coolify/skills.md +25 -0
- package/resources/mcps/mcps/drawio/skills.md +7 -0
- package/resources/mcps/mcps/envoult/skills.md +7 -0
- package/resources/mcps/mcps/gbrain/skills.md +7 -0
- package/resources/mcps/mcps/gitea/skills.md +24 -0
- package/resources/mcps/mcps/higgsfield/README.md +37 -0
- package/resources/mcps/mcps/higgsfield/skills.md +28 -0
- package/resources/mcps/mcps/hostinger-api/skills.md +23 -0
- package/resources/mcps/mcps/kroschuorder/skills.md +7 -0
- package/resources/mcps/mcps/letsfg/skills.md +23 -0
- package/resources/mcps/mcps/marva-blog/README.md +95 -0
- package/resources/mcps/mcps/marva-blog/server.py +843 -0
- package/resources/mcps/mcps/marva-blog/skills.md +7 -0
- package/resources/mcps/mcps/medusadocs/skills.md +35 -0
- package/resources/mcps/mcps/obsidian-vault/skills.md +7 -0
- package/resources/mcps/mcps/omx/README.md +11 -0
- package/resources/mcps/mcps/omx/code-intel/skills.md +29 -0
- package/resources/mcps/mcps/omx/memory/skills.md +24 -0
- package/resources/mcps/mcps/omx/state/README.md +43 -0
- package/resources/mcps/mcps/omx/state/skills.md +33 -0
- package/resources/mcps/mcps/omx/trace/skills.md +25 -0
- package/resources/mcps/mcps/omx/wiki/skills.md +23 -0
- package/resources/mcps/mcps/playwright/skills.md +7 -0
- package/resources/mcps/mcps/polymarket-live/README.md +95 -0
- package/resources/mcps/mcps/polymarket-live/server.py +417 -0
- package/resources/mcps/mcps/polymarket-live/skills.md +7 -0
- package/resources/mcps/mcps/react-grab-mcp/skills.md +26 -0
- package/resources/mcps/mcps/recodee/skills.md +7 -0
- package/resources/mcps/mcps/ruflo/skills.md +7 -0
- package/resources/mcps/mcps/soul/README.md +70 -0
- package/resources/mcps/mcps/soul-skills/README.md +84 -0
- package/resources/mcps/mcps/soul-skills/lint.py +161 -0
- package/resources/mcps/mcps/soul-skills/server.py +299 -0
- package/resources/mcps/mcps/soul-skills/skills.md +7 -0
- package/resources/mcps/plugins/plugins.sanitized.json +113 -0
- package/resources/mcps/scripts/auto-push.sh +68 -0
- package/resources/mcps/scripts/check-mcp-health.py +87 -0
- package/resources/mcps/scripts/install-claude-mcps.py +54 -0
- package/resources/mcps/scripts/install-codex-mcps.py +45 -0
- package/resources/mcps/scripts/refresh-all.sh +11 -0
- package/resources/mcps/scripts/snapshot-mcp-skills.py +268 -0
- package/resources/mcps/scripts/snapshot-mcps.py +275 -0
- package/resources/mcps/templates/claude.mcp.json +48 -0
- package/resources/mcps/templates/codex.mcp.toml +59 -0
- package/resources/skill-packs/deployment-suite.yaml +13 -0
- package/resources/skill-packs/security-review.yaml +11 -0
- package/resources/skills/.claude/settings.json +30 -0
- package/resources/skills/AUDIT-vault-migration.md +246 -0
- package/resources/skills/README.md +135 -0
- package/resources/skills/catalog/catalog.json +685 -0
- package/resources/skills/catalog/known_repos.json +30 -0
- package/resources/skills/docs/install.md +39 -0
- package/resources/skills/docs/installed-sources.tsv +92 -0
- package/resources/skills/mcps/README.md +23 -0
- package/resources/skills/plugins/README.md +21 -0
- package/resources/skills/profiles/all.json +4 -0
- package/resources/skills/profiles/base.json +15 -0
- package/resources/skills/profiles/deploy.json +13 -0
- package/resources/skills/profiles/design.json +14 -0
- package/resources/skills/profiles/frontend.json +13 -0
- package/resources/skills/profiles/medusa.json +15 -0
- package/resources/skills/profiles/orchestration.json +13 -0
- package/resources/skills/profiles/review.json +12 -0
- package/resources/skills/scripts/activate-profile.sh +182 -0
- package/resources/skills/scripts/auto-push-soul.sh +106 -0
- package/resources/skills/scripts/auto-push.sh +70 -0
- package/resources/skills/scripts/import-globals.sh +102 -0
- package/resources/skills/scripts/install-claude.sh +8 -0
- package/resources/skills/scripts/install-codex.sh +8 -0
- package/resources/skills/scripts/install-local.sh +6 -0
- package/resources/skills/scripts/refresh-catalog.sh +207 -0
- package/resources/skills/scripts/soul-lint.sh +66 -0
- package/resources/skills/scripts/sync-all.sh +112 -0
- package/resources/skills/scripts/sync-claude-desktop-mcps.sh +123 -0
- package/resources/skills/skills/browser/playwright/SKILL.md +131 -0
- package/resources/skills/skills/caveman/caveman/SKILL.md +65 -0
- package/resources/skills/skills/caveman/caveman-commit/SKILL.md +64 -0
- package/resources/skills/skills/caveman/caveman-compress/README.md +163 -0
- package/resources/skills/skills/caveman/caveman-compress/SECURITY.md +31 -0
- package/resources/skills/skills/caveman/caveman-compress/SKILL.md +108 -0
- package/resources/skills/skills/caveman/caveman-compress/scripts/__init__.py +9 -0
- package/resources/skills/skills/caveman/caveman-compress/scripts/__main__.py +3 -0
- package/resources/skills/skills/caveman/caveman-compress/scripts/benchmark.py +78 -0
- package/resources/skills/skills/caveman/caveman-compress/scripts/cli.py +73 -0
- package/resources/skills/skills/caveman/caveman-compress/scripts/compress.py +227 -0
- package/resources/skills/skills/caveman/caveman-compress/scripts/detect.py +121 -0
- package/resources/skills/skills/caveman/caveman-compress/scripts/validate.py +189 -0
- package/resources/skills/skills/caveman/caveman-help/SKILL.md +57 -0
- package/resources/skills/skills/caveman/caveman-review/SKILL.md +53 -0
- package/resources/skills/skills/colony/colony/SKILL.md +219 -0
- package/resources/skills/skills/colony/colony-prompts/SKILL.md +224 -0
- package/resources/skills/skills/content/doc/LICENSE.txt +201 -0
- package/resources/skills/skills/content/doc/SKILL.md +81 -0
- package/resources/skills/skills/content/doc/agents/openai.yaml +6 -0
- package/resources/skills/skills/content/doc/assets/doc-small.svg +3 -0
- package/resources/skills/skills/content/doc/assets/doc.png +0 -0
- package/resources/skills/skills/content/doc/scripts/render_docx.py +296 -0
- package/resources/skills/skills/content/pdf/LICENSE.txt +201 -0
- package/resources/skills/skills/content/pdf/SKILL.md +68 -0
- package/resources/skills/skills/content/pdf/agents/openai.yaml +5 -0
- package/resources/skills/skills/content/pdf/assets/pdf.png +0 -0
- package/resources/skills/skills/content/playwright/LICENSE.txt +201 -0
- package/resources/skills/skills/content/playwright/NOTICE.txt +14 -0
- package/resources/skills/skills/content/playwright/SKILL.md +148 -0
- package/resources/skills/skills/content/playwright/agents/openai.yaml +6 -0
- package/resources/skills/skills/content/playwright/assets/playwright-small.svg +3 -0
- package/resources/skills/skills/content/playwright/assets/playwright.png +0 -0
- package/resources/skills/skills/content/playwright/references/cli.md +116 -0
- package/resources/skills/skills/content/playwright/references/workflows.md +95 -0
- package/resources/skills/skills/content/playwright/scripts/playwright_cli.sh +56 -0
- package/resources/skills/skills/deployment/coolify/SKILL.md +124 -0
- package/resources/skills/skills/deployment/coolify/scripts/coolify-preflight.sh +16 -0
- package/resources/skills/skills/deployment/pnpm/GENERATION.md +5 -0
- package/resources/skills/skills/deployment/pnpm/SKILL.md +44 -0
- package/resources/skills/skills/deployment/pnpm/references/best-practices-ci.md +285 -0
- package/resources/skills/skills/deployment/pnpm/references/best-practices-migration.md +291 -0
- package/resources/skills/skills/deployment/pnpm/references/best-practices-performance.md +284 -0
- package/resources/skills/skills/deployment/pnpm/references/core-cli.md +229 -0
- package/resources/skills/skills/deployment/pnpm/references/core-config.md +188 -0
- package/resources/skills/skills/deployment/pnpm/references/core-store.md +179 -0
- package/resources/skills/skills/deployment/pnpm/references/core-workspaces.md +205 -0
- package/resources/skills/skills/deployment/pnpm/references/features-aliases.md +168 -0
- package/resources/skills/skills/deployment/pnpm/references/features-catalogs.md +159 -0
- package/resources/skills/skills/deployment/pnpm/references/features-hooks.md +233 -0
- package/resources/skills/skills/deployment/pnpm/references/features-overrides.md +184 -0
- package/resources/skills/skills/deployment/pnpm/references/features-patches.md +201 -0
- package/resources/skills/skills/deployment/pnpm/references/features-peer-deps.md +250 -0
- package/resources/skills/skills/deployment/supabase/SKILL.md +113 -0
- package/resources/skills/skills/deployment/supabase/assets/feedback-issue-template.md +17 -0
- package/resources/skills/skills/deployment/supabase/references/skill-feedback.md +17 -0
- package/resources/skills/skills/design/brandkit/SKILL.md +799 -0
- package/resources/skills/skills/design/design-taste-frontend/SKILL.md +227 -0
- package/resources/skills/skills/design/gpt-taste/SKILL.md +75 -0
- package/resources/skills/skills/design/high-end-visual-design/SKILL.md +99 -0
- package/resources/skills/skills/design/image-to-code/SKILL.md +1229 -0
- package/resources/skills/skills/design/imagegen-frontend-mobile/SKILL.md +1466 -0
- package/resources/skills/skills/design/imagegen-frontend-web/SKILL.md +988 -0
- package/resources/skills/skills/design/industrial-brutalist-ui/SKILL.md +93 -0
- package/resources/skills/skills/design/kitty-visualize/SKILL.md +106 -0
- package/resources/skills/skills/design/minimalist-ui/SKILL.md +86 -0
- package/resources/skills/skills/design/png-alpha-cleaner/SKILL.md +57 -0
- package/resources/skills/skills/design/png-alpha-cleaner/agents/openai.yaml +7 -0
- package/resources/skills/skills/design/png-alpha-cleaner/scripts/fix_png_alpha.py +244 -0
- package/resources/skills/skills/design/readme-svg-design/SKILL.md +131 -0
- package/resources/skills/skills/design/redesign-existing-projects/SKILL.md +179 -0
- package/resources/skills/skills/design/remotion-best-practices/SKILL.md +340 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/3d.md +86 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/assets/charts-bar-chart.tsx +173 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +100 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +103 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/audio-visualization.md +198 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/audio.md +169 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/calculate-metadata.md +134 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/compositions.md +133 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/display-captions.md +184 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/ffmpeg.md +34 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/get-audio-duration.md +58 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/get-video-dimensions.md +68 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/get-video-duration.md +60 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/gifs.md +141 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/google-fonts.md +72 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/html-in-canvas.md +118 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/images.md +71 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/import-srt-captions.md +69 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/light-leaks.md +73 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/local-fonts.md +65 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/lottie.md +70 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/mapbox.md +412 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/measuring-dom-nodes.md +34 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/measuring-text.md +140 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/parameters.md +109 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/sequencing.md +144 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/sfx.md +30 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/silence-detection.md +71 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/subtitles.md +36 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/tailwind.md +11 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/text-animations.md +20 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/timing.md +136 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/transcribe-captions.md +70 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/transitions.md +197 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/transparent-videos.md +106 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/trimming.md +51 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/videos.md +171 -0
- package/resources/skills/skills/design/remotion-best-practices/rules/voiceover.md +99 -0
- package/resources/skills/skills/design/screenshot/LICENSE.txt +201 -0
- package/resources/skills/skills/design/screenshot/SKILL.md +268 -0
- package/resources/skills/skills/design/screenshot/agents/openai.yaml +6 -0
- package/resources/skills/skills/design/screenshot/assets/screenshot-small.svg +5 -0
- package/resources/skills/skills/design/screenshot/assets/screenshot.png +0 -0
- package/resources/skills/skills/design/screenshot/scripts/ensure_macos_permissions.sh +54 -0
- package/resources/skills/skills/design/screenshot/scripts/macos_display_info.swift +22 -0
- package/resources/skills/skills/design/screenshot/scripts/macos_permissions.swift +40 -0
- package/resources/skills/skills/design/screenshot/scripts/macos_window_info.swift +126 -0
- package/resources/skills/skills/design/screenshot/scripts/take_screenshot.ps1 +163 -0
- package/resources/skills/skills/design/screenshot/scripts/take_screenshot.py +585 -0
- package/resources/skills/skills/design/stitch-design-taste/DESIGN.md +121 -0
- package/resources/skills/skills/design/stitch-design-taste/SKILL.md +185 -0
- package/resources/skills/skills/design/ui-ux-pro-max/SKILL.md +293 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/charts.csv +26 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/colors.csv +97 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/icons.csv +101 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/landing.csv +31 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/products.csv +97 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/astro.csv +54 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/react.csv +54 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/stacks/vue.csv +50 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/styles.csv +68 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/typography.csv +58 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/resources/skills/skills/design/ui-ux-pro-max/data/web-interface.csv +31 -0
- package/resources/skills/skills/design/ui-ux-pro-max/scripts/core.py +253 -0
- package/resources/skills/skills/design/ui-ux-pro-max/scripts/design_system.py +1067 -0
- package/resources/skills/skills/design/ui-ux-pro-max/scripts/search.py +114 -0
- package/resources/skills/skills/github/gh-auth-doctor/SKILL.md +90 -0
- package/resources/skills/skills/github/gh-auth-doctor/scripts/diagnose.sh +126 -0
- package/resources/skills/skills/github/gh-fix-ci/LICENSE.txt +201 -0
- package/resources/skills/skills/github/gh-fix-ci/SKILL.md +70 -0
- package/resources/skills/skills/github/gh-fix-ci/agents/openai.yaml +6 -0
- package/resources/skills/skills/github/gh-fix-ci/assets/github-small.svg +3 -0
- package/resources/skills/skills/github/gh-fix-ci/assets/github.png +0 -0
- package/resources/skills/skills/github/gh-fix-ci/scripts/inspect_pr_checks.py +509 -0
- package/resources/skills/skills/github/gitguardex/SKILL.md +14 -0
- package/resources/skills/skills/github/github/.skillfish.json +10 -0
- package/resources/skills/skills/github/github/SKILL.md +164 -0
- package/resources/skills/skills/github/guardex-merge-skills-to-dev/SKILL.md +59 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/SKILL.md +217 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/marketing-avatars.md +46 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/marketing-modes.md +51 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/marketing-products.md +57 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/marketing-setup-items.md +61 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/media-inputs.md +88 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/model-catalog.md +143 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/prompt-engineering.md +47 -0
- package/resources/skills/skills/higgsfield/higgsfield-generate/references/troubleshooting.md +31 -0
- package/resources/skills/skills/higgsfield/higgsfield-marketplace-cards/SKILL.md +79 -0
- package/resources/skills/skills/higgsfield/higgsfield-product-photoshoot/SKILL.md +200 -0
- package/resources/skills/skills/higgsfield/higgsfield-soul-id/SKILL.md +74 -0
- package/resources/skills/skills/higgsfield/higgsfield-soul-id/references/photo-guide.md +37 -0
- package/resources/skills/skills/higgsfield/higgsfield-soul-id/references/troubleshooting.md +24 -0
- package/resources/skills/skills/hostinger/dns/SKILL.md +301 -0
- package/resources/skills/skills/hostinger/dns/email-dns-setup.md +337 -0
- package/resources/skills/skills/hostinger/domains/SKILL.md +324 -0
- package/resources/skills/skills/hostinger/domains/transfer-guide.md +282 -0
- package/resources/skills/skills/hostinger/hosting/SKILL.md +247 -0
- package/resources/skills/skills/hostinger/vps/SKILL.md +474 -0
- package/resources/skills/skills/hostinger/vps/deployment-workflow.md +375 -0
- package/resources/skills/skills/hostinger/vps/docker-patterns.md +281 -0
- package/resources/skills/skills/hostinger/vps/firewall-patterns.md +209 -0
- package/resources/skills/skills/hostinger/vps/terraform-examples.md +347 -0
- package/resources/skills/skills/medusa/building-admin-dashboard-customizations/SKILL.md +463 -0
- package/resources/skills/skills/medusa/building-admin-dashboard-customizations/references/data-loading.md +530 -0
- package/resources/skills/skills/medusa/building-admin-dashboard-customizations/references/display-patterns.md +436 -0
- package/resources/skills/skills/medusa/building-admin-dashboard-customizations/references/forms.md +400 -0
- package/resources/skills/skills/medusa/building-admin-dashboard-customizations/references/navigation.md +496 -0
- package/resources/skills/skills/medusa/building-admin-dashboard-customizations/references/table-selection.md +407 -0
- package/resources/skills/skills/medusa/building-admin-dashboard-customizations/references/typography.md +210 -0
- package/resources/skills/skills/medusa/building-storefronts/SKILL.md +179 -0
- package/resources/skills/skills/medusa/building-storefronts/references/frontend-integration.md +229 -0
- package/resources/skills/skills/medusa/building-with-medusa/SKILL.md +377 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/api-routes.md +873 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/authentication.md +556 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/custom-modules.md +240 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/data-models.md +103 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/error-handling.md +254 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/frontend-integration.md +229 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/module-links.md +384 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/querying-data.md +1014 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/scheduled-jobs.md +417 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/subscribers-and-events.md +544 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/troubleshooting.md +225 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/workflow-hooks.md +63 -0
- package/resources/skills/skills/medusa/building-with-medusa/reference/workflows.md +516 -0
- package/resources/skills/skills/medusa/creating-internal-agents/SKILL.md +122 -0
- package/resources/skills/skills/medusa/creating-internal-agents/reference/admin-extension.md +392 -0
- package/resources/skills/skills/medusa/creating-internal-agents/reference/agent-setup.md +128 -0
- package/resources/skills/skills/medusa/creating-internal-agents/reference/api-route.md +164 -0
- package/resources/skills/skills/medusa/creating-internal-agents/reference/data-models.md +60 -0
- package/resources/skills/skills/medusa/creating-internal-agents/reference/medusa-exec.md +235 -0
- package/resources/skills/skills/medusa/creating-internal-agents/reference/service.md +100 -0
- package/resources/skills/skills/medusa/creating-internal-agents/reference/streaming.md +112 -0
- package/resources/skills/skills/medusa/db-generate/SKILL.md +23 -0
- package/resources/skills/skills/medusa/db-migrate/SKILL.md +17 -0
- package/resources/skills/skills/medusa/gh-submodule-publish/SKILL.md +146 -0
- package/resources/skills/skills/medusa/gh-submodule-publish/agents/openai.yaml +4 -0
- package/resources/skills/skills/medusa/higgsfield-to-medusa-products/SKILL.md +315 -0
- package/resources/skills/skills/medusa/higgsfield-to-medusa-products/assets/manifest.example.json +39 -0
- package/resources/skills/skills/medusa/higgsfield-to-medusa-products/scripts/load-env.sh +69 -0
- package/resources/skills/skills/medusa/higgsfield-to-medusa-products/scripts/run-pipeline.sh +154 -0
- package/resources/skills/skills/medusa/marva-blog-author/SKILL.md +358 -0
- package/resources/skills/skills/medusa/medusa-local-dev/SKILL.md +100 -0
- package/resources/skills/skills/medusa/medusa-reference/SKILL.md +32 -0
- package/resources/skills/skills/medusa/medusa-reference/references/api-and-auth.md +6 -0
- package/resources/skills/skills/medusa/medusa-reference/references/storefront-integration.md +6 -0
- package/resources/skills/skills/medusa/medusa-reference/references/workflows-and-subscribers.md +6 -0
- package/resources/skills/skills/medusa/medusa-shop-setup/SKILL.md +155 -0
- package/resources/skills/skills/medusa/new-admin-via-api/SKILL.md +112 -0
- package/resources/skills/skills/medusa/new-user/SKILL.md +25 -0
- package/resources/skills/skills/medusa/provision-medusa-s3-bucket/SKILL.md +138 -0
- package/resources/skills/skills/medusa/provision-medusa-s3-bucket/scripts/provision.sh +183 -0
- package/resources/skills/skills/medusa/storefront-best-practices/SKILL.md +422 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/breadcrumbs.md +123 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/cart-popup.md +189 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/country-selector.md +298 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/footer.md +112 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/hero.md +241 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/megamenu.md +239 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/navbar.md +397 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/popups.md +221 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/product-card.md +125 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/product-reviews.md +217 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/product-slider.md +174 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/components/search.md +101 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/connecting-to-backend.md +391 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/design.md +388 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/features/promotions.md +307 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/features/wishlist.md +230 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/account.md +380 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/cart.md +316 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/checkout.md +486 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/home-page.md +264 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/order-confirmation.md +231 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/product-details.md +527 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/product-listing.md +520 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/layouts/static-pages.md +356 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/medusa.md +307 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/mobile-responsiveness.md +183 -0
- package/resources/skills/skills/medusa/storefront-best-practices/reference/seo.md +195 -0
- package/resources/skills/skills/medusa/woocommerce-to-medusa-import/SKILL.md +195 -0
- package/resources/skills/skills/medusa/woocommerce-to-medusa-import/assets/import-woocommerce-products.template.ts +108 -0
- package/resources/skills/skills/medusa/woocommerce-to-medusa-import/references/medusa-v2-product-import.md +63 -0
- package/resources/skills/skills/meta/analyze/SKILL.md +146 -0
- package/resources/skills/skills/meta/ask-claude/SKILL.md +62 -0
- package/resources/skills/skills/meta/ask-gemini/SKILL.md +62 -0
- package/resources/skills/skills/meta/builtin-manager/SKILL.md +66 -0
- package/resources/skills/skills/meta/cue-usage/SKILL.md +149 -0
- package/resources/skills/skills/meta/cue-usage/test/case-1.md +5 -0
- package/resources/skills/skills/meta/doctor/SKILL.md +239 -0
- package/resources/skills/skills/meta/full-output-enforcement/SKILL.md +50 -0
- package/resources/skills/skills/meta/help/SKILL.md +203 -0
- package/resources/skills/skills/meta/just/SKILL.md +62 -0
- package/resources/skills/skills/meta/memory-pressure/SKILL.md +63 -0
- package/resources/skills/skills/meta/note/SKILL.md +63 -0
- package/resources/skills/skills/meta/omx-setup/SKILL.md +135 -0
- package/resources/skills/skills/meta/plugin-creator/SKILL.md +149 -0
- package/resources/skills/skills/meta/plugin-creator/agents/openai.yaml +4 -0
- package/resources/skills/skills/meta/plugin-creator/references/plugin-json-spec.md +158 -0
- package/resources/skills/skills/meta/plugin-creator/scripts/create_basic_plugin.py +291 -0
- package/resources/skills/skills/meta/profile-optimizer/SKILL.md +129 -0
- package/resources/skills/skills/meta/profile-suggest/SKILL.md +96 -0
- package/resources/skills/skills/meta/save-profile/SKILL.md +64 -0
- package/resources/skills/skills/meta/skill-discovery/SKILL.md +88 -0
- package/resources/skills/skills/meta/skill-suggestion/SKILL.md +119 -0
- package/resources/skills/skills/meta/smithery-usage/SKILL.md +68 -0
- package/resources/skills/skills/meta/smithery-usage/test/case-1.md +5 -0
- package/resources/skills/skills/meta/soul/SKILL.md +269 -0
- package/resources/skills/skills/meta/upgrade-stack/SKILL.md +70 -0
- package/resources/skills/skills/meta/workspace-recipes/SKILL.md +63 -0
- package/resources/skills/skills/nvidia/aiq-research/SKILL.md +86 -0
- package/resources/skills/skills/nvidia/cuopt-developer/SKILL.md +234 -0
- package/resources/skills/skills/nvidia/cuopt-developer/evals/evals.json +716 -0
- package/resources/skills/skills/nvidia/cuopt-developer/resources/build_and_test.md +43 -0
- package/resources/skills/skills/nvidia/cuopt-developer/resources/contributing.md +113 -0
- package/resources/skills/skills/nvidia/cuopt-developer/resources/conventions.md +81 -0
- package/resources/skills/skills/nvidia/cuopt-developer/resources/first_time_setup.md +32 -0
- package/resources/skills/skills/nvidia/cuopt-developer/resources/python_bindings.md +233 -0
- package/resources/skills/skills/nvidia/cuopt-developer/resources/troubleshooting.md +26 -0
- package/resources/skills/skills/nvidia/cuopt-install/SKILL.md +128 -0
- package/resources/skills/skills/nvidia/cuopt-install/evals/evals.json +213 -0
- package/resources/skills/skills/nvidia/cuopt-install/resources/verification_examples.md +172 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/SKILL.md +69 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/README.md +33 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/lp_basic/README.md +15 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/lp_basic/lp_simple.c +109 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/lp_duals/README.md +14 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/lp_duals/lp_duals.c +115 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/lp_warmstart/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/milp_basic/README.md +12 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/milp_basic/milp_simple.c +102 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/milp_production_planning/README.md +12 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/milp_production_planning/milp_production.c +98 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/mps_solver/README.md +14 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/mps_solver/data/sample.mps +19 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/assets/mps_solver/mps_solver.c +107 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/resources/examples.md +291 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/skill-card.md +40 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-c/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/SKILL.md +77 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/assets/README.md +21 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/assets/lp_production/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/assets/lp_production/production.mps +16 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/assets/lp_simple/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/assets/lp_simple/sample.mps +19 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/assets/milp_facility/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/assets/milp_facility/facility.mps +27 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/skill-card.md +39 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-cli/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/SKILL.md +278 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/README.md +17 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/least_squares/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/least_squares/model.py +24 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/lp_basic/README.md +7 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/lp_basic/model.py +36 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/lp_duals/README.md +7 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/lp_duals/model.py +38 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/lp_warmstart/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/lp_warmstart/model.py +52 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/maximization_workaround/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/maximization_workaround/model.py +22 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/milp_basic/README.md +10 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/milp_basic/incumbent_callback.py +50 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/milp_basic/model.py +36 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/milp_production_planning/README.md +5 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/milp_production_planning/model.py +33 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/mps_solver/README.md +88 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/mps_solver/data/README.md +82 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/mps_solver/data/sample.mps +19 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/mps_solver/model.py +283 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/mps_solver/results.md +90 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/portfolio/README.md +7 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/assets/portfolio/model.py +49 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/evals/SOURCES.md +40 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/evals/evals.json +1091 -0
- package/resources/skills/skills/nvidia/cuopt-numerical-optimization-api-python/resources/qp_examples.md +198 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/SKILL.md +103 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/assets/README.md +10 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/assets/pdp_basic/README.md +7 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/assets/pdp_basic/model.py +56 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/assets/vrp_basic/README.md +7 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/assets/vrp_basic/model.py +31 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/resources/examples.md +249 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/resources/server_examples.md +204 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/skill-card.md +38 -0
- package/resources/skills/skills/nvidia/cuopt-routing-api-python/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/SKILL.md +81 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/README.md +14 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/lp_basic/README.md +10 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/lp_basic/client.py +84 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/milp_basic/README.md +6 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/milp_basic/client.py +82 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/pdp_basic/README.md +6 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/pdp_basic/client.py +97 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/vrp_basic/README.md +10 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/vrp_basic/client.py +101 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/vrp_simple/README.md +6 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/assets/vrp_simple/client.py +95 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/skill-card.md +38 -0
- package/resources/skills/skills/nvidia/cuopt-server-api-python/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/cuopt-server-common/SKILL.md +47 -0
- package/resources/skills/skills/nvidia/cuopt-server-common/skill-card.md +38 -0
- package/resources/skills/skills/nvidia/cuopt-server-common/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/cuopt-user-rules/SKILL.md +222 -0
- package/resources/skills/skills/nvidia/cuopt-user-rules/skill-card.md +39 -0
- package/resources/skills/skills/nvidia/cuopt-user-rules/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/numerical-optimization-formulation/SKILL.md +263 -0
- package/resources/skills/skills/nvidia/numerical-optimization-formulation/skill-card.md +38 -0
- package/resources/skills/skills/nvidia/numerical-optimization-formulation/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/routing-formulation/SKILL.md +32 -0
- package/resources/skills/skills/nvidia/routing-formulation/skill-card.md +38 -0
- package/resources/skills/skills/nvidia/routing-formulation/skill.oms.sig +1 -0
- package/resources/skills/skills/nvidia/skill-evolution/SKILL.md +211 -0
- package/resources/skills/skills/nvidia/skill-evolution/skill-card.md +37 -0
- package/resources/skills/skills/nvidia/skill-evolution/skill.oms.sig +1 -0
- package/resources/skills/skills/obsidian/json-canvas/SKILL.md +245 -0
- package/resources/skills/skills/obsidian/json-canvas/references/EXAMPLES.md +329 -0
- package/resources/skills/skills/obsidian/obsidian-bases/SKILL.md +498 -0
- package/resources/skills/skills/obsidian/obsidian-bases/references/FUNCTIONS_REFERENCE.md +173 -0
- package/resources/skills/skills/obsidian/obsidian-cli/SKILL.md +107 -0
- package/resources/skills/skills/obsidian/obsidian-markdown/SKILL.md +197 -0
- package/resources/skills/skills/obsidian/obsidian-markdown/references/CALLOUTS.md +58 -0
- package/resources/skills/skills/obsidian/obsidian-markdown/references/EMBEDS.md +63 -0
- package/resources/skills/skills/obsidian/obsidian-markdown/references/PROPERTIES.md +61 -0
- package/resources/skills/skills/orchestration/authmux/SKILL.md +80 -0
- package/resources/skills/skills/orchestration/codex-fleet-login/SKILL.md +99 -0
- package/resources/skills/skills/orchestration/codex-fleet-login/codex_fleet_login.sh +202 -0
- package/resources/skills/skills/orchestration/pipeline/SKILL.md +86 -0
- package/resources/skills/skills/orchestration/visual-ralph/SKILL.md +161 -0
- package/resources/skills/skills/orchestration/worker/SKILL.md +106 -0
- package/resources/skills/skills/polymarket/polymarket-predictions-audit/SKILL.md +82 -0
- package/resources/skills/skills/polymarket/polymarket-research/SKILL.md +80 -0
- package/resources/skills/skills/private/myvps/SKILL.md +74 -0
- package/resources/skills/skills/private/myvps/agents/openai.yaml +4 -0
- package/resources/skills/skills/private/myvps/scripts/myvps.sh +48 -0
- package/resources/skills/skills/private/myvps/scripts/remote-supabase-admin.sh +120 -0
- package/resources/skills/skills/research/awesome-rust-search/SKILL.md +152 -0
- package/resources/skills/skills/research/cloakbrowser/SKILL.md +85 -0
- package/resources/skills/skills/research/defuddle/SKILL.md +41 -0
- package/resources/skills/skills/research/find-skills/SKILL.md +143 -0
- package/resources/skills/skills/research/flight-search/SKILL.md +293 -0
- package/resources/skills/skills/research/flight-search/references/api-reference.md +247 -0
- package/resources/skills/skills/research/flight-search/references/mcp-setup.md +157 -0
- package/resources/skills/skills/research/keyword-research/SKILL.md +283 -0
- package/resources/skills/skills/research/keyword-research/references/example-report.md +96 -0
- package/resources/skills/skills/research/keyword-research/references/instructions-detail.md +198 -0
- package/resources/skills/skills/research/keyword-research/references/keyword-intent-taxonomy.md +324 -0
- package/resources/skills/skills/research/keyword-research/references/keyword-prioritization-framework.md +41 -0
- package/resources/skills/skills/research/keyword-research/references/topic-cluster-templates.md +286 -0
- package/resources/skills/skills/research/obscura/SKILL.md +181 -0
- package/resources/skills/skills/research/openai-docs/LICENSE.txt +201 -0
- package/resources/skills/skills/research/openai-docs/SKILL.md +57 -0
- package/resources/skills/skills/research/openai-docs/agents/openai.yaml +14 -0
- package/resources/skills/skills/research/openai-docs/assets/openai-small.svg +3 -0
- package/resources/skills/skills/research/openai-docs/assets/openai.png +0 -0
- package/resources/skills/skills/review/api-tester/SKILL.md +165 -0
- package/resources/skills/skills/review/code-review/SKILL.md +288 -0
- package/resources/skills/skills/review/security-best-practices/LICENSE.txt +201 -0
- package/resources/skills/skills/review/security-best-practices/SKILL.md +87 -0
- package/resources/skills/skills/review/security-best-practices/agents/openai.yaml +4 -0
- package/resources/skills/skills/review/security-best-practices/references/golang-general-backend-security.md +826 -0
- package/resources/skills/skills/review/security-best-practices/references/javascript-express-web-server-security.md +1158 -0
- package/resources/skills/skills/review/security-best-practices/references/javascript-general-web-frontend-security.md +747 -0
- package/resources/skills/skills/review/security-best-practices/references/javascript-jquery-web-frontend-security.md +678 -0
- package/resources/skills/skills/review/security-best-practices/references/javascript-typescript-nextjs-web-server-security.md +1144 -0
- package/resources/skills/skills/review/security-best-practices/references/javascript-typescript-react-web-frontend-security.md +990 -0
- package/resources/skills/skills/review/security-best-practices/references/javascript-typescript-vue-web-frontend-security.md +791 -0
- package/resources/skills/skills/review/security-best-practices/references/python-django-web-server-security.md +882 -0
- package/resources/skills/skills/review/security-best-practices/references/python-fastapi-web-server-security.md +1036 -0
- package/resources/skills/skills/review/security-best-practices/references/python-flask-web-server-security.md +705 -0
- package/resources/skills/skills/review/security-review/SKILL.md +301 -0
- package/resources/skills/skills/review/wtf/SKILL.md +105 -0
- package/resources/skills/skills/stripe/stripe-best-practices/SKILL.md +34 -0
- package/resources/skills/skills/stripe/stripe-best-practices/references/billing.md +36 -0
- package/resources/skills/skills/stripe/stripe-best-practices/references/connect.md +48 -0
- package/resources/skills/skills/stripe/stripe-best-practices/references/payments.md +79 -0
- package/resources/skills/skills/stripe/stripe-best-practices/references/security.md +109 -0
- package/resources/skills/skills/stripe/stripe-best-practices/references/treasury.md +16 -0
- package/resources/skills/skills/stripe/stripe-webhooks/SKILL.md +162 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/express/README.md +62 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/express/package.json +19 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/express/src/index.js +82 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/express/test/webhook.test.js +132 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/fastapi/README.md +66 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/fastapi/main.py +75 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/fastapi/requirements.txt +6 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/fastapi/test_webhook.py +121 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/nextjs/README.md +60 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/nextjs/app/webhooks/stripe/route.ts +73 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/nextjs/package.json +23 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/nextjs/test/webhook.test.ts +145 -0
- package/resources/skills/skills/stripe/stripe-webhooks/examples/nextjs/vitest.config.ts +8 -0
- package/resources/skills/skills/stripe/stripe-webhooks/references/overview.md +61 -0
- package/resources/skills/skills/stripe/stripe-webhooks/references/setup.md +94 -0
- package/resources/skills/skills/stripe/stripe-webhooks/references/verification.md +155 -0
- package/src/commands/_index.ts +226 -0
- package/src/commands/ask.ts +107 -0
- package/src/commands/auto-detect.ts +53 -0
- package/src/commands/builtin.ts +90 -0
- package/src/commands/cloud.ts +269 -0
- package/src/commands/colony-dispatch.ts +25 -0
- package/src/commands/completions.ts +113 -0
- package/src/commands/cost.ts +128 -0
- package/src/commands/create-profile.ts +128 -0
- package/src/commands/current.ts +44 -0
- package/src/commands/diff.ts +87 -0
- package/src/commands/doctor.ts +527 -0
- package/src/commands/handoff.ts +95 -0
- package/src/commands/icon.ts +98 -0
- package/src/commands/import-profile.ts +130 -0
- package/src/commands/init.ts +97 -0
- package/src/commands/launch.test.ts +116 -0
- package/src/commands/launch.ts +593 -0
- package/src/commands/list.ts +31 -0
- package/src/commands/lock.ts +88 -0
- package/src/commands/marketplace.ts +263 -0
- package/src/commands/mcps.ts +272 -0
- package/src/commands/migrate-symlinks.test.ts +96 -0
- package/src/commands/migrate-symlinks.ts +127 -0
- package/src/commands/new.ts +292 -0
- package/src/commands/optimizer.ts +573 -0
- package/src/commands/packs.ts +112 -0
- package/src/commands/quick.ts +52 -0
- package/src/commands/replay.ts +128 -0
- package/src/commands/scan.ts +55 -0
- package/src/commands/security.ts +256 -0
- package/src/commands/shell.test.ts +55 -0
- package/src/commands/shell.ts +192 -0
- package/src/commands/skills-lint.ts +148 -0
- package/src/commands/skills-new.ts +92 -0
- package/src/commands/skills-pin.ts +101 -0
- package/src/commands/skills-test.ts +140 -0
- package/src/commands/skills.ts +1115 -0
- package/src/commands/snapshot.ts +108 -0
- package/src/commands/sources.ts +201 -0
- package/src/commands/stats.ts +59 -0
- package/src/commands/status.ts +186 -0
- package/src/commands/trace.ts +118 -0
- package/src/commands/tree.ts +89 -0
- package/src/commands/update.ts +113 -0
- package/src/commands/use.ts +8 -0
- package/src/commands/validate.ts +132 -0
- package/src/commands/watch.ts +137 -0
- package/src/commands/why.ts +115 -0
- package/src/index.ts +174 -0
- package/src/lib/analytics.ts +79 -0
- package/src/lib/auto-detect.ts +101 -0
- package/src/lib/brand-icons.ts +187 -0
- package/src/lib/cache.ts +101 -0
- package/src/lib/colony-dispatch.ts +42 -0
- package/src/lib/conflict-detector.ts +140 -0
- package/src/lib/cwd-resolver.test.ts +98 -0
- package/src/lib/cwd-resolver.ts +86 -0
- package/src/lib/handoff.ts +80 -0
- package/src/lib/help.ts +12 -0
- package/src/lib/kitty-image.test.ts +211 -0
- package/src/lib/kitty-image.ts +360 -0
- package/src/lib/lazy-mcp-wrapper.sh +21 -0
- package/src/lib/manifest-cache.ts +97 -0
- package/src/lib/mcp-materializer.test.ts +358 -0
- package/src/lib/mcp-materializer.ts +317 -0
- package/src/lib/pack-resolver.ts +69 -0
- package/src/lib/picker.test.ts +28 -0
- package/src/lib/picker.ts +103 -0
- package/src/lib/profile-generator.test.ts +237 -0
- package/src/lib/profile-generator.ts +1162 -0
- package/src/lib/profile-linter.test.ts +239 -0
- package/src/lib/profile-linter.ts +658 -0
- package/src/lib/profile-loader.schema-delta.test.ts +90 -0
- package/src/lib/profile-loader.test.ts +336 -0
- package/src/lib/profile-loader.ts +450 -0
- package/src/lib/project-scanner.ts +87 -0
- package/src/lib/ratings.ts +55 -0
- package/src/lib/resolver-local.test.ts +234 -0
- package/src/lib/resolver-local.ts +334 -0
- package/src/lib/resolver-npx.test.ts +309 -0
- package/src/lib/resolver-npx.ts +333 -0
- package/src/lib/resolver-plugins.test.ts +197 -0
- package/src/lib/resolver-plugins.ts +217 -0
- package/src/lib/runtime-lock.ts +65 -0
- package/src/lib/runtime-materializer.test.ts +278 -0
- package/src/lib/runtime-materializer.ts +433 -0
- package/src/lib/scan-plugins.test.ts +190 -0
- package/src/lib/scan-plugins.ts +491 -0
- package/src/lib/skill-compressor.ts +70 -0
- package/src/lib/skill-dependencies.ts +119 -0
- package/src/lib/skill-scorer.ts +83 -0
- package/src/lib/star-prompt.ts +81 -0
- package/src/lib/webhooks.ts +58 -0
|
@@ -0,0 +1,1115 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `cue skills` — manage skills in profiles.
|
|
3
|
+
*
|
|
4
|
+
* Subcommands:
|
|
5
|
+
* list [--json] — skills in active profile
|
|
6
|
+
* available [--json] — all skills NOT in active profile
|
|
7
|
+
* search <query> [--json] — fuzzy search across catalog
|
|
8
|
+
* add <repo> [flags] — wraps `npx skills add` with profile hook
|
|
9
|
+
* add-to-profile <id> — append skill to active profile.yaml
|
|
10
|
+
* remove-from-profile <id> — remove skill from active profile.yaml
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
import { spawnSync } from "node:child_process";
|
|
14
|
+
import { readFileSync, readdirSync, existsSync } from "node:fs";
|
|
15
|
+
import { readFile, writeFile } from "node:fs/promises";
|
|
16
|
+
import { resolve, dirname, join } from "node:path";
|
|
17
|
+
import { fileURLToPath } from "node:url";
|
|
18
|
+
|
|
19
|
+
import { listProfiles, loadProfile } from "../lib/profile-loader";
|
|
20
|
+
import { resolveProfileForCwd } from "../lib/cwd-resolver";
|
|
21
|
+
import { listAllSkillIds } from "../lib/resolver-local";
|
|
22
|
+
|
|
23
|
+
const REPO_ROOT = resolve(dirname(fileURLToPath(import.meta.url)), "..", "..");
|
|
24
|
+
const PROFILES_DIR = process.env.CUE_PROFILES_DIR ?? join(REPO_ROOT, "profiles");
|
|
25
|
+
const SKILLS_ROOT = join(REPO_ROOT, "resources", "skills", "skills");
|
|
26
|
+
|
|
27
|
+
// ---------------------------------------------------------------------------
|
|
28
|
+
// Skill metadata parsing
|
|
29
|
+
// ---------------------------------------------------------------------------
|
|
30
|
+
|
|
31
|
+
interface SkillMeta {
|
|
32
|
+
id: string;
|
|
33
|
+
description: string;
|
|
34
|
+
tags: string[];
|
|
35
|
+
category: string;
|
|
36
|
+
requires_mcps: string[];
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
function parseSkillMeta(id: string): SkillMeta {
|
|
40
|
+
const parts = id.split("/");
|
|
41
|
+
const category = parts.length === 2 ? parts[0]! : "unknown";
|
|
42
|
+
const skillDir = join(SKILLS_ROOT, id);
|
|
43
|
+
const skillMd = join(skillDir, "SKILL.md");
|
|
44
|
+
let description = "";
|
|
45
|
+
let tags: string[] = [];
|
|
46
|
+
let requires_mcps: string[] = [];
|
|
47
|
+
|
|
48
|
+
try {
|
|
49
|
+
const content = readFileSync(skillMd, "utf8");
|
|
50
|
+
// Parse YAML frontmatter
|
|
51
|
+
const fmMatch = content.match(/^---\n([\s\S]*?)\n---/);
|
|
52
|
+
if (fmMatch) {
|
|
53
|
+
const fm = fmMatch[1]!;
|
|
54
|
+
const descMatch = fm.match(/^description:\s*["']?(.+?)["']?\s*$/m);
|
|
55
|
+
if (descMatch) description = descMatch[1]!;
|
|
56
|
+
const tagsMatch = fm.match(/^tags:\s*\[([^\]]*)\]/m);
|
|
57
|
+
if (tagsMatch) tags = tagsMatch[1]!.split(",").map(t => t.trim().replace(/['"]/g, "")).filter(Boolean);
|
|
58
|
+
const mcpMatch = fm.match(/^requires_mcps:\s*\[([^\]]*)\]/m);
|
|
59
|
+
if (mcpMatch) requires_mcps = mcpMatch[1]!.split(",").map(t => t.trim().replace(/['"]/g, "")).filter(Boolean);
|
|
60
|
+
}
|
|
61
|
+
// Fallback: first non-empty line after frontmatter as description
|
|
62
|
+
if (!description) {
|
|
63
|
+
const body = fmMatch ? content.slice(fmMatch[0].length) : content;
|
|
64
|
+
const firstLine = body.split("\n").find(l => l.trim() && !l.startsWith("#"));
|
|
65
|
+
if (firstLine) description = firstLine.trim().slice(0, 120);
|
|
66
|
+
}
|
|
67
|
+
} catch { /* skill dir may not have SKILL.md */ }
|
|
68
|
+
|
|
69
|
+
return { id, description, tags, category, requires_mcps };
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// ---------------------------------------------------------------------------
|
|
73
|
+
// Subcommands
|
|
74
|
+
// ---------------------------------------------------------------------------
|
|
75
|
+
|
|
76
|
+
async function getActiveProfileName(): Promise<string | null> {
|
|
77
|
+
try {
|
|
78
|
+
return await resolveProfileForCwd(process.cwd());
|
|
79
|
+
} catch {
|
|
80
|
+
return null;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
async function getActiveProfileSkillIds(): Promise<string[]> {
|
|
85
|
+
const name = await getActiveProfileName();
|
|
86
|
+
if (!name) return [];
|
|
87
|
+
try {
|
|
88
|
+
const profile = await loadProfile(name);
|
|
89
|
+
return profile.skills.local.map(s => typeof s === "string" ? s : s.id);
|
|
90
|
+
} catch {
|
|
91
|
+
return [];
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
async function cmdList(json: boolean): Promise<number> {
|
|
96
|
+
const ids = await getActiveProfileSkillIds();
|
|
97
|
+
const metas = ids.map(parseSkillMeta);
|
|
98
|
+
|
|
99
|
+
if (json) {
|
|
100
|
+
process.stdout.write(JSON.stringify(metas, null, 2) + "\n");
|
|
101
|
+
} else {
|
|
102
|
+
const profileName = await getActiveProfileName();
|
|
103
|
+
process.stdout.write(`Skills in profile "${profileName}" (${metas.length}):\n\n`);
|
|
104
|
+
const grouped = new Map<string, SkillMeta[]>();
|
|
105
|
+
for (const m of metas) {
|
|
106
|
+
const list = grouped.get(m.category) ?? [];
|
|
107
|
+
list.push(m);
|
|
108
|
+
grouped.set(m.category, list);
|
|
109
|
+
}
|
|
110
|
+
for (const [cat, skills] of [...grouped.entries()].sort()) {
|
|
111
|
+
process.stdout.write(` ${cat}/\n`);
|
|
112
|
+
for (const s of skills) {
|
|
113
|
+
const tagStr = s.tags.length ? ` [${s.tags.join(", ")}]` : "";
|
|
114
|
+
process.stdout.write(` ${s.id.split("/")[1]} — ${s.description}${tagStr}\n`);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return 0;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
async function cmdAvailable(json: boolean): Promise<number> {
|
|
122
|
+
const allIds = await listAllSkillIds();
|
|
123
|
+
const activeIds = new Set(await getActiveProfileSkillIds());
|
|
124
|
+
const available = allIds.filter(id => !activeIds.has(id));
|
|
125
|
+
const metas = available.map(parseSkillMeta);
|
|
126
|
+
|
|
127
|
+
if (json) {
|
|
128
|
+
process.stdout.write(JSON.stringify(metas, null, 2) + "\n");
|
|
129
|
+
} else {
|
|
130
|
+
process.stdout.write(`Available skills not in active profile (${metas.length}):\n\n`);
|
|
131
|
+
const grouped = new Map<string, SkillMeta[]>();
|
|
132
|
+
for (const m of metas) {
|
|
133
|
+
const list = grouped.get(m.category) ?? [];
|
|
134
|
+
list.push(m);
|
|
135
|
+
grouped.set(m.category, list);
|
|
136
|
+
}
|
|
137
|
+
for (const [cat, skills] of [...grouped.entries()].sort()) {
|
|
138
|
+
process.stdout.write(` ${cat}/\n`);
|
|
139
|
+
for (const s of skills) {
|
|
140
|
+
process.stdout.write(` ${s.id.split("/")[1]} — ${s.description}\n`);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
return 0;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
async function cmdSearch(query: string, json: boolean): Promise<number> {
|
|
148
|
+
const allIds = await listAllSkillIds();
|
|
149
|
+
const metas = allIds.map(parseSkillMeta);
|
|
150
|
+
const q = query.toLowerCase();
|
|
151
|
+
|
|
152
|
+
const matches = metas.filter(m =>
|
|
153
|
+
m.id.toLowerCase().includes(q) ||
|
|
154
|
+
m.description.toLowerCase().includes(q) ||
|
|
155
|
+
m.tags.some(t => t.toLowerCase().includes(q)) ||
|
|
156
|
+
m.category.toLowerCase().includes(q)
|
|
157
|
+
);
|
|
158
|
+
|
|
159
|
+
if (json) {
|
|
160
|
+
process.stdout.write(JSON.stringify(matches, null, 2) + "\n");
|
|
161
|
+
} else {
|
|
162
|
+
if (matches.length === 0) {
|
|
163
|
+
process.stdout.write(`No skills matching "${query}"\n`);
|
|
164
|
+
} else {
|
|
165
|
+
process.stdout.write(`Skills matching "${query}" (${matches.length}):\n\n`);
|
|
166
|
+
for (const m of matches) {
|
|
167
|
+
const tagStr = m.tags.length ? ` [${m.tags.join(", ")}]` : "";
|
|
168
|
+
const mcpStr = m.requires_mcps.length ? ` (needs: ${m.requires_mcps.join(", ")})` : "";
|
|
169
|
+
process.stdout.write(` ${m.id} — ${m.description}${tagStr}${mcpStr}\n`);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
return 0;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
async function cmdAddToProfile(id: string, preview = false): Promise<number> {
|
|
177
|
+
const profileName = await getActiveProfileName();
|
|
178
|
+
if (!profileName) {
|
|
179
|
+
process.stderr.write("No active profile. Pin one with `echo <name> > .cue-profile`\n");
|
|
180
|
+
return 1;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
// Check profile lock
|
|
184
|
+
const { isProfileLocked } = await import("./lock");
|
|
185
|
+
const lock = isProfileLocked(profileName);
|
|
186
|
+
if (lock.locked) {
|
|
187
|
+
process.stderr.write(`❌ Profile "${profileName}" is locked${lock.by ? ` by ${lock.by}` : ""}.\n`);
|
|
188
|
+
if (lock.reason) process.stderr.write(` Reason: ${lock.reason}\n`);
|
|
189
|
+
process.stderr.write(` Unlock with: cue unlock ${profileName}\n`);
|
|
190
|
+
return 1;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
// Validate skill exists
|
|
194
|
+
const allIds = await listAllSkillIds();
|
|
195
|
+
if (!allIds.includes(id)) {
|
|
196
|
+
process.stderr.write(`Skill "${id}" not found. Run \`cue skills search\` to find valid IDs.\n`);
|
|
197
|
+
return 1;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
const yamlPath = join(PROFILES_DIR, profileName, "profile.yaml");
|
|
201
|
+
const content = await readFile(yamlPath, "utf8");
|
|
202
|
+
|
|
203
|
+
// Check if already present
|
|
204
|
+
if (content.includes(`- ${id}`)) {
|
|
205
|
+
process.stderr.write(`Skill "${id}" already in profile "${profileName}"\n`);
|
|
206
|
+
return 0;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
// Check requires_mcps
|
|
210
|
+
const meta = parseSkillMeta(id);
|
|
211
|
+
|
|
212
|
+
// Preview mode
|
|
213
|
+
if (preview) {
|
|
214
|
+
process.stdout.write(`Preview: adding "${id}" to profile "${profileName}"\n\n`);
|
|
215
|
+
process.stdout.write(`Changes:\n`);
|
|
216
|
+
process.stdout.write(` + 1 skill (${id})\n`);
|
|
217
|
+
if (meta.requires_mcps.length) {
|
|
218
|
+
const missing = meta.requires_mcps.filter(m => !content.includes(`- ${m}`));
|
|
219
|
+
if (missing.length) process.stdout.write(` + ${missing.length} MCP(s): ${missing.join(", ")}\n`);
|
|
220
|
+
}
|
|
221
|
+
process.stdout.write(`\nRun without --preview to apply.\n`);
|
|
222
|
+
return 0;
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
let updated = content;
|
|
226
|
+
|
|
227
|
+
if (meta.requires_mcps.length > 0) {
|
|
228
|
+
for (const mcp of meta.requires_mcps) {
|
|
229
|
+
if (!updated.includes(`- ${mcp}`)) {
|
|
230
|
+
if (updated.includes("mcps:")) {
|
|
231
|
+
const lines = updated.split("\n");
|
|
232
|
+
const mcpsIdx = lines.findIndex(l => l.match(/^mcps:/));
|
|
233
|
+
if (mcpsIdx >= 0) {
|
|
234
|
+
let insertIdx = mcpsIdx + 1;
|
|
235
|
+
while (insertIdx < lines.length && lines[insertIdx]?.match(/^\s+-\s/)) insertIdx++;
|
|
236
|
+
if (!lines.slice(mcpsIdx, insertIdx).some(l => l.includes(mcp))) {
|
|
237
|
+
lines.splice(insertIdx, 0, ` - ${mcp}`);
|
|
238
|
+
updated = lines.join("\n");
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
} else {
|
|
242
|
+
updated = updated.trimEnd() + `\nmcps:\n - ${mcp}\n`;
|
|
243
|
+
}
|
|
244
|
+
process.stdout.write(`Auto-added required MCP: ${mcp}\n`);
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
// Add skill to skills.local
|
|
250
|
+
if (updated.includes(" local:")) {
|
|
251
|
+
const lines = updated.split("\n");
|
|
252
|
+
const localIdx = lines.findIndex(l => l.match(/^\s+local:/));
|
|
253
|
+
let insertIdx = localIdx + 1;
|
|
254
|
+
while (insertIdx < lines.length && lines[insertIdx]?.match(/^\s{4}-\s/)) insertIdx++;
|
|
255
|
+
lines.splice(insertIdx, 0, ` - ${id}`);
|
|
256
|
+
updated = lines.join("\n");
|
|
257
|
+
} else if (updated.includes("skills:")) {
|
|
258
|
+
updated = updated.replace(/^(skills:)\s*$/m, `$1\n local:\n - ${id}`);
|
|
259
|
+
} else {
|
|
260
|
+
updated = updated.trimEnd() + `\nskills:\n local:\n - ${id}\n`;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
await writeFile(yamlPath, updated);
|
|
264
|
+
process.stdout.write(`Added "${id}" to profile "${profileName}"\n`);
|
|
265
|
+
return 0;
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
async function cmdRemoveFromProfile(id: string): Promise<number> {
|
|
269
|
+
const profileName = await getActiveProfileName();
|
|
270
|
+
if (!profileName) {
|
|
271
|
+
process.stderr.write("No active profile.\n");
|
|
272
|
+
return 1;
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
const yamlPath = join(PROFILES_DIR, profileName, "profile.yaml");
|
|
276
|
+
const content = await readFile(yamlPath, "utf8");
|
|
277
|
+
|
|
278
|
+
const lines = content.split("\n");
|
|
279
|
+
const filtered = lines.filter(l => !l.match(new RegExp(`^\\s+-\\s+${id.replace("/", "/")}\\s*$`)));
|
|
280
|
+
|
|
281
|
+
if (filtered.length === lines.length) {
|
|
282
|
+
process.stderr.write(`Skill "${id}" not found in profile "${profileName}"\n`);
|
|
283
|
+
return 1;
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
await writeFile(yamlPath, filtered.join("\n"));
|
|
287
|
+
process.stdout.write(`Removed "${id}" from profile "${profileName}"\n`);
|
|
288
|
+
return 0;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
// ---------------------------------------------------------------------------
|
|
292
|
+
// `cue skills add <repo>` — wraps npx with post-install profile hook
|
|
293
|
+
// ---------------------------------------------------------------------------
|
|
294
|
+
|
|
295
|
+
import * as p from "@clack/prompts";
|
|
296
|
+
import { copyFileSync } from "node:fs";
|
|
297
|
+
import { homedir } from "node:os";
|
|
298
|
+
|
|
299
|
+
const INSTALL_DIRS = [
|
|
300
|
+
join(homedir(), ".claude", "skills"),
|
|
301
|
+
join(homedir(), ".codex", "skills"),
|
|
302
|
+
];
|
|
303
|
+
|
|
304
|
+
function getInstalledSkills(): Set<string> {
|
|
305
|
+
const skills = new Set<string>();
|
|
306
|
+
for (const dir of INSTALL_DIRS) {
|
|
307
|
+
try { for (const e of readdirSync(dir)) skills.add(e); } catch {}
|
|
308
|
+
}
|
|
309
|
+
return skills;
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
function inferProfileName(repo: string): string {
|
|
313
|
+
const slug = repo.split("/").pop() ?? repo;
|
|
314
|
+
return slug
|
|
315
|
+
.replace(/^anthropic-/i, "")
|
|
316
|
+
.replace(/-skills?$/i, "")
|
|
317
|
+
.toLowerCase()
|
|
318
|
+
.replace(/[^a-z0-9-]/g, "-")
|
|
319
|
+
.replace(/-+/g, "-")
|
|
320
|
+
.replace(/^-|-$/g, "") || "new-profile";
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
function inferEmoji(repo: string, profileName: string): string {
|
|
324
|
+
const text = `${repo} ${profileName}`.toLowerCase();
|
|
325
|
+
const map: [RegExp, string][] = [
|
|
326
|
+
[/cyber|security|hack|pentest|vuln/, "🛡️"],
|
|
327
|
+
[/ai|ml|machine.?learn|neural|llm|model/, "🤖"],
|
|
328
|
+
[/web|frontend|react|vue|angular|css/, "🌐"],
|
|
329
|
+
[/backend|api|server|express|fastify/, "⚙️"],
|
|
330
|
+
[/data|analytics|pipeline|etl|warehouse/, "📊"],
|
|
331
|
+
[/cloud|aws|azure|gcp|infra|terraform/, "☁️"],
|
|
332
|
+
[/mobile|ios|android|flutter|react.?native/, "📱"],
|
|
333
|
+
[/devops|ci.?cd|deploy|docker|k8s|kubernetes/, "🚀"],
|
|
334
|
+
[/database|sql|postgres|mongo|redis/, "🗄️"],
|
|
335
|
+
[/design|ui|ux|figma|brand/, "🎨"],
|
|
336
|
+
[/marketing|seo|growth|ads|campaign/, "📣"],
|
|
337
|
+
[/writing|docs|content|blog|copy/, "✍️"],
|
|
338
|
+
[/research|science|paper|academic/, "🔬"],
|
|
339
|
+
[/finance|payment|stripe|billing|crypto/, "💰"],
|
|
340
|
+
[/game|unity|unreal|godot/, "🎮"],
|
|
341
|
+
[/media|video|audio|image|photo/, "🎬"],
|
|
342
|
+
[/network|dns|tcp|http|proxy/, "🔌"],
|
|
343
|
+
[/test|qa|quality|jest|pytest/, "🧪"],
|
|
344
|
+
[/rust|cargo|crate/, "🦀"],
|
|
345
|
+
[/python|pip|django|flask/, "🐍"],
|
|
346
|
+
[/node|npm|bun|deno|javascript|typescript/, "💛"],
|
|
347
|
+
[/forensic|incident|threat|malware/, "🔍"],
|
|
348
|
+
[/crypto|encrypt|ssl|tls|cert/, "🔐"],
|
|
349
|
+
[/linux|ubuntu|debian|arch/, "🐧"],
|
|
350
|
+
[/windows|powershell/, "🪟"],
|
|
351
|
+
[/git|github|gitlab/, "🐙"],
|
|
352
|
+
];
|
|
353
|
+
for (const [re, emoji] of map) {
|
|
354
|
+
if (re.test(text)) return emoji;
|
|
355
|
+
}
|
|
356
|
+
return "🔧";
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
function inferImageUrl(repo: string, profileName: string): string | null {
|
|
360
|
+
const text = `${repo} ${profileName}`.toLowerCase();
|
|
361
|
+
// Map keywords to well-known icon URLs (simple-icons via CDN)
|
|
362
|
+
const map: [RegExp, string][] = [
|
|
363
|
+
[/cyber|security|hack|pentest/, "https://cdn.simpleicons.org/hackthebox/9FEF00"],
|
|
364
|
+
[/aws/, "https://cdn.simpleicons.org/amazonaws/FF9900"],
|
|
365
|
+
[/azure/, "https://cdn.simpleicons.org/microsoftazure/0078D4"],
|
|
366
|
+
[/gcp|google.?cloud/, "https://cdn.simpleicons.org/googlecloud/4285F4"],
|
|
367
|
+
[/docker/, "https://cdn.simpleicons.org/docker/2496ED"],
|
|
368
|
+
[/kubernetes|k8s/, "https://cdn.simpleicons.org/kubernetes/326CE5"],
|
|
369
|
+
[/terraform/, "https://cdn.simpleicons.org/terraform/844FBA"],
|
|
370
|
+
[/react/, "https://cdn.simpleicons.org/react/61DAFB"],
|
|
371
|
+
[/vue/, "https://cdn.simpleicons.org/vuedotjs/4FC08D"],
|
|
372
|
+
[/angular/, "https://cdn.simpleicons.org/angular/DD0031"],
|
|
373
|
+
[/python|django|flask/, "https://cdn.simpleicons.org/python/3776AB"],
|
|
374
|
+
[/rust/, "https://cdn.simpleicons.org/rust/000000"],
|
|
375
|
+
[/node|express/, "https://cdn.simpleicons.org/nodedotjs/339933"],
|
|
376
|
+
[/typescript/, "https://cdn.simpleicons.org/typescript/3178C6"],
|
|
377
|
+
[/go|golang/, "https://cdn.simpleicons.org/go/00ADD8"],
|
|
378
|
+
[/linux/, "https://cdn.simpleicons.org/linux/FCC624"],
|
|
379
|
+
[/git|github/, "https://cdn.simpleicons.org/github/181717"],
|
|
380
|
+
[/stripe/, "https://cdn.simpleicons.org/stripe/635BFF"],
|
|
381
|
+
[/postgres/, "https://cdn.simpleicons.org/postgresql/4169E1"],
|
|
382
|
+
[/mongo/, "https://cdn.simpleicons.org/mongodb/47A248"],
|
|
383
|
+
[/redis/, "https://cdn.simpleicons.org/redis/DC382D"],
|
|
384
|
+
[/nginx/, "https://cdn.simpleicons.org/nginx/009639"],
|
|
385
|
+
[/splunk/, "https://cdn.simpleicons.org/splunk/000000"],
|
|
386
|
+
[/elastic|elk/, "https://cdn.simpleicons.org/elastic/005571"],
|
|
387
|
+
[/anthropic|claude/, "https://cdn.simpleicons.org/anthropic/191919"],
|
|
388
|
+
[/openai/, "https://cdn.simpleicons.org/openai/412991"],
|
|
389
|
+
[/nvidia|cuda/, "https://cdn.simpleicons.org/nvidia/76B900"],
|
|
390
|
+
[/forensic|incident|threat|malware/, "https://cdn.simpleicons.org/virustotal/394EFF"],
|
|
391
|
+
];
|
|
392
|
+
for (const [re, url] of map) {
|
|
393
|
+
if (re.test(text)) return url;
|
|
394
|
+
}
|
|
395
|
+
return null;
|
|
396
|
+
}
|
|
397
|
+
|
|
398
|
+
async function cmdNpxAdd(args: string[]): Promise<number> {
|
|
399
|
+
const addArgs = args.slice(1); // skip "add"
|
|
400
|
+
const repo = addArgs.find((a) => !a.startsWith("-") && !["claude-code", "codex", "*"].includes(a));
|
|
401
|
+
|
|
402
|
+
// #6: If -y/--yes without --skill, inject --skill "*" to skip npx's interactive picker
|
|
403
|
+
const passedArgs = [...args];
|
|
404
|
+
const hasYes = passedArgs.includes("-y") || passedArgs.includes("--yes");
|
|
405
|
+
const hasSkill = passedArgs.includes("-s") || passedArgs.includes("--skill");
|
|
406
|
+
if (hasYes && !hasSkill) {
|
|
407
|
+
passedArgs.push("--skill", "*");
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
// Snapshot before
|
|
411
|
+
const before = getInstalledSkills();
|
|
412
|
+
|
|
413
|
+
// Always use inherit so npx's interactive picker works on TTY
|
|
414
|
+
const res = spawnSync("npx", ["skills", ...passedArgs], {
|
|
415
|
+
stdio: "inherit",
|
|
416
|
+
encoding: "utf8",
|
|
417
|
+
});
|
|
418
|
+
|
|
419
|
+
if (res.status !== 0) return res.status ?? 1;
|
|
420
|
+
|
|
421
|
+
// Detect new skills by diffing before/after
|
|
422
|
+
const after = getInstalledSkills();
|
|
423
|
+
let newSkills = [...after].filter((s) => !before.has(s));
|
|
424
|
+
|
|
425
|
+
// If no new skills (re-install), check if a profile for this repo already exists
|
|
426
|
+
// and offer to update it, or use the installed skills that match the repo name
|
|
427
|
+
let isReinstall = false;
|
|
428
|
+
if (newSkills.length === 0 && repo) {
|
|
429
|
+
isReinstall = true;
|
|
430
|
+
// Use the profile name we'd infer to find matching skills already on disk
|
|
431
|
+
const profileSlug = inferProfileName(repo);
|
|
432
|
+
// Check if profile exists
|
|
433
|
+
const profileYaml = join(PROFILES_DIR, profileSlug, "profile.yaml");
|
|
434
|
+
if (existsSync(profileYaml)) {
|
|
435
|
+
// Profile exists — read its skills as the "new" skills for update flow
|
|
436
|
+
const content = readFileSync(profileYaml, "utf8");
|
|
437
|
+
const skillMatches = content.match(/^\s{4}-\s+(.+)$/gm);
|
|
438
|
+
if (skillMatches) {
|
|
439
|
+
newSkills = skillMatches.map((l) => l.replace(/^\s+-\s+/, "").trim());
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
// If profile doesn't exist or has no skills, scan disk for repo's skills
|
|
443
|
+
if (newSkills.length === 0) {
|
|
444
|
+
// All skills currently on disk that weren't in "before" snapshot of profiles
|
|
445
|
+
newSkills = [...after];
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
// If still nothing, the install was likely cancelled — don't trigger hook
|
|
450
|
+
if (newSkills.length === 0) return 0;
|
|
451
|
+
|
|
452
|
+
// #7: Fetch GitHub repo description
|
|
453
|
+
let repoDescription = "";
|
|
454
|
+
if (repo) {
|
|
455
|
+
try {
|
|
456
|
+
const apiRes = spawnSync("curl", ["-fsSL", `https://api.github.com/repos/${repo}`], {
|
|
457
|
+
stdio: ["ignore", "pipe", "pipe"], encoding: "utf8", timeout: 5000,
|
|
458
|
+
});
|
|
459
|
+
if (apiRes.status === 0 && apiRes.stdout) {
|
|
460
|
+
const data = JSON.parse(apiRes.stdout);
|
|
461
|
+
if (data.description) repoDescription = data.description;
|
|
462
|
+
}
|
|
463
|
+
} catch {}
|
|
464
|
+
}
|
|
465
|
+
|
|
466
|
+
// #8: Dedup — check which skills already exist in other profiles (direct only, not inherited)
|
|
467
|
+
const existingMap = new Map<string, string[]>(); // skill → [profile names]
|
|
468
|
+
try {
|
|
469
|
+
const allProfiles = await listProfiles();
|
|
470
|
+
for (const pName of allProfiles) {
|
|
471
|
+
try {
|
|
472
|
+
const yamlContent = readFileSync(join(PROFILES_DIR, pName, "profile.yaml"), "utf8");
|
|
473
|
+
// Extract skill slugs directly from YAML (lines like " - category/skill" or " - skill")
|
|
474
|
+
const skillMatches = yamlContent.match(/^\s{4}-\s+(.+)$/gm);
|
|
475
|
+
if (!skillMatches) continue;
|
|
476
|
+
for (const line of skillMatches) {
|
|
477
|
+
const sid = line.replace(/^\s+-\s+/, "").trim();
|
|
478
|
+
const slug = sid.split("/").pop() ?? sid;
|
|
479
|
+
if (newSkills.includes(slug)) {
|
|
480
|
+
const list = existingMap.get(slug) ?? [];
|
|
481
|
+
list.push(pName);
|
|
482
|
+
existingMap.set(slug, list);
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
} catch {}
|
|
486
|
+
}
|
|
487
|
+
} catch {}
|
|
488
|
+
|
|
489
|
+
// --- Post-install profile hook ---
|
|
490
|
+
p.intro(isReinstall ? "🔄 Skills already installed" : "🎉 Skills installed successfully");
|
|
491
|
+
p.log.info(`${newSkills.length} skills from ${repo ?? "install"}`);
|
|
492
|
+
|
|
493
|
+
// Show dedup warning (skip for re-installs since we already know)
|
|
494
|
+
if (!isReinstall && existingMap.size > 0) {
|
|
495
|
+
const dupCount = existingMap.size;
|
|
496
|
+
const examples = [...existingMap.entries()].slice(0, 5)
|
|
497
|
+
.map(([skill, profiles]) => ` ${skill} → ${profiles.join(", ")}`)
|
|
498
|
+
.join("\n");
|
|
499
|
+
p.log.warning(`${dupCount} skill(s) already in other profiles:\n${examples}${dupCount > 5 ? `\n … +${dupCount - 5} more` : ""}`);
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
// Check if a profile for this repo already exists
|
|
503
|
+
const inferredName = repo ? inferProfileName(repo) : null;
|
|
504
|
+
const existingProfilePath = inferredName ? join(PROFILES_DIR, inferredName, "profile.yaml") : null;
|
|
505
|
+
const profileExists = existingProfilePath && existsSync(existingProfilePath);
|
|
506
|
+
|
|
507
|
+
// Compute diff stats for update hint
|
|
508
|
+
let diffHint = "sync skills list";
|
|
509
|
+
let currentProfileSkills: string[] = [];
|
|
510
|
+
if (profileExists && existingProfilePath) {
|
|
511
|
+
try {
|
|
512
|
+
const content = readFileSync(existingProfilePath, "utf8");
|
|
513
|
+
const matches = content.match(/^\s{4}-\s+(.+)$/gm);
|
|
514
|
+
if (matches) {
|
|
515
|
+
currentProfileSkills = matches.map((l) => l.replace(/^\s+-\s+/, "").trim());
|
|
516
|
+
}
|
|
517
|
+
const currentSet = new Set(currentProfileSkills);
|
|
518
|
+
const newSet = new Set(newSkills);
|
|
519
|
+
const added = newSkills.filter((s) => !currentSet.has(s));
|
|
520
|
+
const removed = currentProfileSkills.filter((s) => !newSet.has(s));
|
|
521
|
+
const parts: string[] = [];
|
|
522
|
+
if (added.length > 0) parts.push(`\x1b[32m+${added.length} new\x1b[0m`);
|
|
523
|
+
if (removed.length > 0) parts.push(`\x1b[31m-${removed.length} removed\x1b[0m`);
|
|
524
|
+
if (added.length === 0 && removed.length === 0) parts.push("no changes");
|
|
525
|
+
diffHint = parts.join(", ");
|
|
526
|
+
} catch {}
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
const action = await p.select({
|
|
530
|
+
message: profileExists
|
|
531
|
+
? `Profile "${inferredName}" already exists. What to do?`
|
|
532
|
+
: "Add these skills to a cue profile?",
|
|
533
|
+
options: [
|
|
534
|
+
...(profileExists ? [{ value: "update", label: `Update "${inferredName}" profile`, hint: diffHint }] : []),
|
|
535
|
+
{ value: "create", label: "Create a new profile", hint: !profileExists && repo ? inferProfileName(repo) : undefined },
|
|
536
|
+
{ value: "existing", label: "Add to a different profile" },
|
|
537
|
+
{ value: "skip", label: "Skip" },
|
|
538
|
+
],
|
|
539
|
+
});
|
|
540
|
+
if (p.isCancel(action) || action === "skip") {
|
|
541
|
+
p.outro("Done. Run `cue list` to see profiles.");
|
|
542
|
+
return 0;
|
|
543
|
+
}
|
|
544
|
+
|
|
545
|
+
// Handle "update" — overwrite skills in existing profile
|
|
546
|
+
if (action === "update" && existingProfilePath && inferredName) {
|
|
547
|
+
const content = await readFile(existingProfilePath, "utf8");
|
|
548
|
+
const currentSet = new Set(currentProfileSkills);
|
|
549
|
+
const newSet = new Set(newSkills);
|
|
550
|
+
const added = newSkills.filter((s) => !currentSet.has(s));
|
|
551
|
+
const removed = currentProfileSkills.filter((s) => !newSet.has(s));
|
|
552
|
+
|
|
553
|
+
// Replace the entire skills.local section
|
|
554
|
+
const skillLines = newSkills.map((s) => ` - ${s}`).join("\n");
|
|
555
|
+
let updated: string;
|
|
556
|
+
if (content.includes(" local:")) {
|
|
557
|
+
const lines = content.split("\n");
|
|
558
|
+
const localIdx = lines.findIndex((l) => l.match(/^\s+local:/));
|
|
559
|
+
let endIdx = localIdx + 1;
|
|
560
|
+
while (endIdx < lines.length && lines[endIdx]?.match(/^\s{4}-\s/)) endIdx++;
|
|
561
|
+
lines.splice(localIdx + 1, endIdx - localIdx - 1, ...newSkills.map((s) => ` - ${s}`));
|
|
562
|
+
updated = lines.join("\n");
|
|
563
|
+
} else if (content.includes("skills:")) {
|
|
564
|
+
updated = content.replace(/^(skills:)\s*$/m, `$1\n local:\n${skillLines}`);
|
|
565
|
+
} else {
|
|
566
|
+
updated = content.trimEnd() + `\nskills:\n local:\n${skillLines}\n`;
|
|
567
|
+
}
|
|
568
|
+
await writeFile(existingProfilePath, updated);
|
|
569
|
+
|
|
570
|
+
const parts: string[] = [`${newSkills.length} total`];
|
|
571
|
+
if (added.length > 0) parts.push(`+${added.length} new`);
|
|
572
|
+
if (removed.length > 0) parts.push(`-${removed.length} removed`);
|
|
573
|
+
p.outro(`Updated "${inferredName}" — ${parts.join(", ")}`);
|
|
574
|
+
return 0;
|
|
575
|
+
}
|
|
576
|
+
|
|
577
|
+
// #3: Smart subset — group by prefix
|
|
578
|
+
let selectedSkills = newSkills;
|
|
579
|
+
if (newSkills.length > 10) {
|
|
580
|
+
const scope = await p.select({
|
|
581
|
+
message: `Include all ${newSkills.length} skills or pick a subset?`,
|
|
582
|
+
options: [
|
|
583
|
+
{ value: "all", label: `All ${newSkills.length} skills` },
|
|
584
|
+
{ value: "groups", label: "Select by category/group" },
|
|
585
|
+
{ value: "individual", label: "Pick individual skills" },
|
|
586
|
+
],
|
|
587
|
+
});
|
|
588
|
+
if (p.isCancel(scope)) { p.cancel("cancelled"); return 130; }
|
|
589
|
+
|
|
590
|
+
if (scope === "groups") {
|
|
591
|
+
// Group skills by their first word/prefix (e.g. "analyzing-*", "testing-*", "securing-*")
|
|
592
|
+
const groups = new Map<string, string[]>();
|
|
593
|
+
for (const s of newSkills) {
|
|
594
|
+
const prefix = s.split("-").slice(0, 1).join("-");
|
|
595
|
+
const list = groups.get(prefix) ?? [];
|
|
596
|
+
list.push(s);
|
|
597
|
+
groups.set(prefix, list);
|
|
598
|
+
}
|
|
599
|
+
// Sort groups by size descending
|
|
600
|
+
const sortedGroups = [...groups.entries()].sort((a, b) => b[1].length - a[1].length);
|
|
601
|
+
|
|
602
|
+
const chosenGroups = await p.multiselect({
|
|
603
|
+
message: "Select skill groups (space to toggle)",
|
|
604
|
+
options: sortedGroups.map(([prefix, skills]) => ({
|
|
605
|
+
value: prefix,
|
|
606
|
+
label: `${prefix}-* (${skills.length} skills)`,
|
|
607
|
+
hint: skills.slice(0, 3).join(", ") + (skills.length > 3 ? " …" : ""),
|
|
608
|
+
})),
|
|
609
|
+
required: true,
|
|
610
|
+
});
|
|
611
|
+
if (p.isCancel(chosenGroups)) { p.cancel("cancelled"); return 130; }
|
|
612
|
+
const selectedPrefixes = new Set(chosenGroups as string[]);
|
|
613
|
+
selectedSkills = newSkills.filter((s) => selectedPrefixes.has(s.split("-").slice(0, 1).join("-")));
|
|
614
|
+
p.log.info(`Selected ${selectedSkills.length} skills from ${selectedPrefixes.size} groups`);
|
|
615
|
+
} else if (scope === "individual") {
|
|
616
|
+
const chosen = await p.multiselect({
|
|
617
|
+
message: "Select skills (space to toggle)",
|
|
618
|
+
options: newSkills.map((s) => ({ value: s, label: s })),
|
|
619
|
+
required: true,
|
|
620
|
+
});
|
|
621
|
+
if (p.isCancel(chosen)) { p.cancel("cancelled"); return 130; }
|
|
622
|
+
selectedSkills = chosen as string[];
|
|
623
|
+
}
|
|
624
|
+
}
|
|
625
|
+
|
|
626
|
+
if (action === "create") {
|
|
627
|
+
const suggested = repo ? inferProfileName(repo) : "new-profile";
|
|
628
|
+
const name = await p.text({
|
|
629
|
+
message: "Profile name",
|
|
630
|
+
placeholder: suggested,
|
|
631
|
+
initialValue: suggested,
|
|
632
|
+
validate: (v) => { if (!/^[a-z][a-z0-9-]{1,63}$/.test(v)) return "Must be kebab-case"; },
|
|
633
|
+
});
|
|
634
|
+
if (p.isCancel(name)) { p.cancel("cancelled"); return 130; }
|
|
635
|
+
|
|
636
|
+
// Icon: emoji or image
|
|
637
|
+
const iconType = await p.select({
|
|
638
|
+
message: "Profile icon",
|
|
639
|
+
options: [
|
|
640
|
+
{ value: "emoji", label: "Emoji", hint: "type or paste an emoji" },
|
|
641
|
+
{ value: "image", label: "Image file", hint: "paste path to .png/.jpg" },
|
|
642
|
+
],
|
|
643
|
+
});
|
|
644
|
+
if (p.isCancel(iconType)) { p.cancel("cancelled"); return 130; }
|
|
645
|
+
|
|
646
|
+
let icon = "🔒";
|
|
647
|
+
let iconImagePath: string | null = null;
|
|
648
|
+
|
|
649
|
+
if (iconType === "emoji") {
|
|
650
|
+
const suggestedEmoji = inferEmoji(repo ?? "", name as string);
|
|
651
|
+
const emojiInput = await p.text({ message: "Icon emoji", placeholder: suggestedEmoji, initialValue: suggestedEmoji });
|
|
652
|
+
if (p.isCancel(emojiInput)) { p.cancel("cancelled"); return 130; }
|
|
653
|
+
icon = emojiInput as string;
|
|
654
|
+
} else {
|
|
655
|
+
// #4: GitHub avatar as fallback
|
|
656
|
+
const suggestedUrl = inferImageUrl(repo ?? "", name as string);
|
|
657
|
+
const ghAvatar = repo ? `https://github.com/${repo.split("/")[0]}.png?size=128` : null;
|
|
658
|
+
const imgSource = await p.select({
|
|
659
|
+
message: "Image source",
|
|
660
|
+
options: [
|
|
661
|
+
...(suggestedUrl ? [{ value: "suggested", label: "Download suggested icon", hint: suggestedUrl }] : []),
|
|
662
|
+
...(ghAvatar ? [{ value: "avatar", label: "GitHub avatar", hint: ghAvatar }] : []),
|
|
663
|
+
{ value: "url", label: "Download from URL" },
|
|
664
|
+
{ value: "local", label: "Local file path" },
|
|
665
|
+
],
|
|
666
|
+
});
|
|
667
|
+
if (p.isCancel(imgSource)) { p.cancel("cancelled"); return 130; }
|
|
668
|
+
|
|
669
|
+
if (imgSource === "suggested" || imgSource === "url" || imgSource === "avatar") {
|
|
670
|
+
let url = imgSource === "suggested" ? (suggestedUrl ?? "") : imgSource === "avatar" ? (ghAvatar ?? "") : "";
|
|
671
|
+
if (imgSource === "url") {
|
|
672
|
+
const urlInput = await p.text({ message: "Image URL", placeholder: "https://..." });
|
|
673
|
+
if (p.isCancel(urlInput)) { p.cancel("cancelled"); return 130; }
|
|
674
|
+
url = urlInput as string;
|
|
675
|
+
}
|
|
676
|
+
const { mkdtempSync } = await import("node:fs");
|
|
677
|
+
const { tmpdir } = await import("node:os");
|
|
678
|
+
const tmpDir = mkdtempSync(join(tmpdir(), "cue-icon-"));
|
|
679
|
+
const ext = url.match(/\.(png|jpg|jpeg|svg|webp)/i)?.[0] ?? ".png";
|
|
680
|
+
const tmpFile = join(tmpDir, `logo${ext}`);
|
|
681
|
+
const dlRes = spawnSync("curl", ["-fsSL", "-o", tmpFile, url], { stdio: "pipe", encoding: "utf8" });
|
|
682
|
+
if (dlRes.status === 0 && existsSync(tmpFile)) {
|
|
683
|
+
iconImagePath = tmpFile;
|
|
684
|
+
p.log.success(`Downloaded icon`);
|
|
685
|
+
} else {
|
|
686
|
+
p.log.warning(`Download failed. Using emoji fallback.`);
|
|
687
|
+
icon = inferEmoji(repo ?? "", name as string);
|
|
688
|
+
}
|
|
689
|
+
} else {
|
|
690
|
+
const imgInput = await p.text({
|
|
691
|
+
message: "Image path",
|
|
692
|
+
placeholder: "/path/to/logo.png",
|
|
693
|
+
validate: (v) => {
|
|
694
|
+
if (!v) return "Path required";
|
|
695
|
+
if (!existsSync(v)) return `Not found: ${v}`;
|
|
696
|
+
if (!/\.(png|jpg|jpeg|svg|webp)$/i.test(v)) return "Must be .png, .jpg, .svg, or .webp";
|
|
697
|
+
},
|
|
698
|
+
});
|
|
699
|
+
if (p.isCancel(imgInput)) { p.cancel("cancelled"); return 130; }
|
|
700
|
+
iconImagePath = imgInput as string;
|
|
701
|
+
}
|
|
702
|
+
}
|
|
703
|
+
|
|
704
|
+
// Description — use GitHub repo description as default
|
|
705
|
+
const defaultDesc = repoDescription || `Skills from ${repo ?? "install"}`;
|
|
706
|
+
const desc = await p.text({
|
|
707
|
+
message: "Description",
|
|
708
|
+
placeholder: defaultDesc,
|
|
709
|
+
initialValue: defaultDesc,
|
|
710
|
+
});
|
|
711
|
+
if (p.isCancel(desc)) { p.cancel("cancelled"); return 130; }
|
|
712
|
+
|
|
713
|
+
// #1: Preview card before confirm
|
|
714
|
+
const previewIcon = iconImagePath ? `${icon} + logo image` : icon;
|
|
715
|
+
p.log.message(`\n┌─ Profile Preview ─────────────────────\n│ Name: ${name}\n│ Icon: ${previewIcon}\n│ Description: ${(desc as string).slice(0, 60)}\n│ Skills: ${selectedSkills.length}\n│ Inherits: core\n└───────────────────────────────────────`);
|
|
716
|
+
|
|
717
|
+
const confirm = await p.confirm({ message: "Create this profile?" });
|
|
718
|
+
if (p.isCancel(confirm) || !confirm) { p.cancel("cancelled"); return 130; }
|
|
719
|
+
|
|
720
|
+
// Create profile
|
|
721
|
+
const { run: createProfile } = await import("./create-profile");
|
|
722
|
+
const code = await createProfile([
|
|
723
|
+
name as string, "--icon", icon, "--description", desc as string,
|
|
724
|
+
"--skills", selectedSkills.join(","),
|
|
725
|
+
]);
|
|
726
|
+
|
|
727
|
+
// Copy image if provided
|
|
728
|
+
if (code === 0 && iconImagePath) {
|
|
729
|
+
const profileDir = join(PROFILES_DIR, name as string);
|
|
730
|
+
const ext = iconImagePath.match(/\.\w+$/)?.[0] ?? ".png";
|
|
731
|
+
const destName = `logo${ext}`;
|
|
732
|
+
copyFileSync(iconImagePath, join(profileDir, destName));
|
|
733
|
+
const yaml = await readFile(join(profileDir, "profile.yaml"), "utf8");
|
|
734
|
+
await writeFile(join(profileDir, "profile.yaml"), yaml.replace(/^(icon:.*\n)/m, `$1iconImage: "${destName}"\n`));
|
|
735
|
+
}
|
|
736
|
+
|
|
737
|
+
if (code !== 0) return code;
|
|
738
|
+
|
|
739
|
+
// #2: Auto-pin option
|
|
740
|
+
const pin = await p.confirm({ message: `Pin "${name}" to current directory?`, initialValue: true });
|
|
741
|
+
if (!p.isCancel(pin) && pin) {
|
|
742
|
+
await writeFile(join(process.cwd(), ".cue-profile"), `${name}\n`);
|
|
743
|
+
p.log.success(`Pinned → .cue-profile`);
|
|
744
|
+
}
|
|
745
|
+
|
|
746
|
+
// #10: Post-create launch prompt
|
|
747
|
+
const launch = await p.confirm({ message: `Launch claude with "${name}" now?`, initialValue: false });
|
|
748
|
+
if (!p.isCancel(launch) && launch) {
|
|
749
|
+
p.outro(`Launching claude with profile "${name}"…`);
|
|
750
|
+
const { execSync } = await import("node:child_process");
|
|
751
|
+
execSync("claude", { stdio: "inherit", env: { ...process.env } });
|
|
752
|
+
} else {
|
|
753
|
+
p.outro(`Profile "${name}" created with ${selectedSkills.length} skills. Run \`cue use ${name}\` to activate.`);
|
|
754
|
+
}
|
|
755
|
+
return 0;
|
|
756
|
+
}
|
|
757
|
+
|
|
758
|
+
if (action === "existing") {
|
|
759
|
+
const profiles = await listProfiles();
|
|
760
|
+
if (profiles.length === 0) { p.log.error("No profiles found."); return 1; }
|
|
761
|
+
|
|
762
|
+
// Build profile options with skill counts
|
|
763
|
+
const profileOptions = profiles.map((n) => {
|
|
764
|
+
let skillCount = 0;
|
|
765
|
+
try {
|
|
766
|
+
const content = readFileSync(join(PROFILES_DIR, n, "profile.yaml"), "utf8");
|
|
767
|
+
const matches = content.match(/^\s{4}-\s+/gm);
|
|
768
|
+
if (matches) skillCount = matches.length;
|
|
769
|
+
} catch {}
|
|
770
|
+
return { value: n, label: `${n} (${skillCount} skills)` };
|
|
771
|
+
});
|
|
772
|
+
|
|
773
|
+
const target = await p.select({
|
|
774
|
+
message: "Which profile?",
|
|
775
|
+
options: profileOptions,
|
|
776
|
+
});
|
|
777
|
+
if (p.isCancel(target)) { p.cancel("cancelled"); return 130; }
|
|
778
|
+
|
|
779
|
+
// #8: Show dedup for the target profile specifically
|
|
780
|
+
const targetYamlPath = join(PROFILES_DIR, target as string, "profile.yaml");
|
|
781
|
+
const content = await readFile(targetYamlPath, "utf8");
|
|
782
|
+
const alreadyInTarget = selectedSkills.filter((s) => content.includes(s));
|
|
783
|
+
if (alreadyInTarget.length > 0) {
|
|
784
|
+
p.log.warning(`${alreadyInTarget.length} skill(s) already in "${target}", will skip duplicates`);
|
|
785
|
+
selectedSkills = selectedSkills.filter((s) => !content.includes(s));
|
|
786
|
+
if (selectedSkills.length === 0) {
|
|
787
|
+
p.outro(`All skills already in "${target}". Nothing to add.`);
|
|
788
|
+
return 0;
|
|
789
|
+
}
|
|
790
|
+
}
|
|
791
|
+
|
|
792
|
+
const skillLines = selectedSkills.map((s) => ` - ${s}`);
|
|
793
|
+
|
|
794
|
+
let updated: string;
|
|
795
|
+
if (content.includes(" local:")) {
|
|
796
|
+
const lines = content.split("\n");
|
|
797
|
+
const localIdx = lines.findIndex((l) => l.match(/^\s+local:/));
|
|
798
|
+
let insertIdx = localIdx + 1;
|
|
799
|
+
while (insertIdx < lines.length && lines[insertIdx]?.match(/^\s{4}-\s/)) insertIdx++;
|
|
800
|
+
lines.splice(insertIdx, 0, ...skillLines);
|
|
801
|
+
updated = lines.join("\n");
|
|
802
|
+
} else if (content.includes("skills:")) {
|
|
803
|
+
updated = content.replace(/^(skills:)\s*$/m, `$1\n local:\n${skillLines.join("\n")}`);
|
|
804
|
+
} else {
|
|
805
|
+
updated = content.trimEnd() + `\nskills:\n local:\n${skillLines.join("\n")}\n`;
|
|
806
|
+
}
|
|
807
|
+
|
|
808
|
+
await writeFile(targetYamlPath, updated);
|
|
809
|
+
p.outro(`Added ${selectedSkills.length} skills to "${target}".`);
|
|
810
|
+
return 0;
|
|
811
|
+
}
|
|
812
|
+
|
|
813
|
+
return 0;
|
|
814
|
+
}
|
|
815
|
+
|
|
816
|
+
// ---------------------------------------------------------------------------
|
|
817
|
+
// `cue skills rank` — ranked list of skills by usage
|
|
818
|
+
// ---------------------------------------------------------------------------
|
|
819
|
+
|
|
820
|
+
async function cmdRank(args: string[]): Promise<number> {
|
|
821
|
+
const limit = parseInt(args.find((a) => /^\d+$/.test(a)) ?? "30", 10);
|
|
822
|
+
const projectsDir = join(homedir(), ".claude", "projects");
|
|
823
|
+
|
|
824
|
+
// Scan session transcripts for skill reads
|
|
825
|
+
const usage = new Map<string, number>();
|
|
826
|
+
try {
|
|
827
|
+
const res = spawnSync("grep", ["-roh", "skills/[a-z][a-z0-9-]*/SKILL.md", projectsDir], {
|
|
828
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
829
|
+
encoding: "utf8",
|
|
830
|
+
timeout: 15000,
|
|
831
|
+
});
|
|
832
|
+
if (res.status === 0 && res.stdout) {
|
|
833
|
+
for (const line of res.stdout.split("\n")) {
|
|
834
|
+
const match = line.match(/skills\/([a-z][a-z0-9-]*)\/SKILL\.md/);
|
|
835
|
+
if (match) {
|
|
836
|
+
const skill = match[1]!;
|
|
837
|
+
usage.set(skill, (usage.get(skill) ?? 0) + 1);
|
|
838
|
+
}
|
|
839
|
+
}
|
|
840
|
+
}
|
|
841
|
+
} catch {}
|
|
842
|
+
|
|
843
|
+
if (usage.size === 0) {
|
|
844
|
+
process.stdout.write("No usage data found. Skills are tracked when agents read SKILL.md files.\n");
|
|
845
|
+
return 0;
|
|
846
|
+
}
|
|
847
|
+
|
|
848
|
+
const sorted = [...usage.entries()].sort((a, b) => b[1] - a[1]);
|
|
849
|
+
const maxCount = sorted[0]![1];
|
|
850
|
+
const barMax = 20;
|
|
851
|
+
|
|
852
|
+
process.stdout.write(`\n 📊 Skill Usage Ranking (${sorted.length} skills tracked)\n\n`);
|
|
853
|
+
process.stdout.write(` ${"#".padEnd(4)}${"Skill".padEnd(40)}${"Uses".padStart(6)} Graph\n`);
|
|
854
|
+
process.stdout.write(` ${"─".repeat(4)}${"─".repeat(40)}${"─".repeat(6)} ${"─".repeat(barMax)}\n`);
|
|
855
|
+
|
|
856
|
+
for (let i = 0; i < Math.min(limit, sorted.length); i++) {
|
|
857
|
+
const [skill, count] = sorted[i]!;
|
|
858
|
+
const barLen = Math.max(1, Math.round((count / maxCount) * barMax));
|
|
859
|
+
const bar = "█".repeat(barLen) + "░".repeat(barMax - barLen);
|
|
860
|
+
const rank = `${i + 1}.`.padEnd(4);
|
|
861
|
+
process.stdout.write(` ${rank}${skill.padEnd(40)}${String(count).padStart(6)} ${bar}\n`);
|
|
862
|
+
}
|
|
863
|
+
|
|
864
|
+
if (sorted.length > limit) {
|
|
865
|
+
process.stdout.write(`\n … ${sorted.length - limit} more (use \`cue skills rank ${sorted.length}\` to show all)\n`);
|
|
866
|
+
}
|
|
867
|
+
|
|
868
|
+
process.stdout.write("\n");
|
|
869
|
+
return 0;
|
|
870
|
+
}
|
|
871
|
+
|
|
872
|
+
// ---------------------------------------------------------------------------
|
|
873
|
+
// #12: Skill ratings
|
|
874
|
+
// ---------------------------------------------------------------------------
|
|
875
|
+
|
|
876
|
+
async function cmdRate(id: string, vote: string): Promise<number> {
|
|
877
|
+
if (!id || !["up", "down"].includes(vote)) {
|
|
878
|
+
process.stderr.write("Usage: cue skills rate <skill-id> up|down\n");
|
|
879
|
+
return 1;
|
|
880
|
+
}
|
|
881
|
+
const { rateSkill, getRating } = await import("../lib/ratings");
|
|
882
|
+
rateSkill(id, vote === "up");
|
|
883
|
+
const r = getRating(id);
|
|
884
|
+
process.stdout.write(`${vote === "up" ? "👍" : "👎"} Rated "${id}" — score: ${(r?.up ?? 0) - (r?.down ?? 0)} (${r?.up ?? 0}↑ ${r?.down ?? 0}↓)\n`);
|
|
885
|
+
return 0;
|
|
886
|
+
}
|
|
887
|
+
|
|
888
|
+
// ---------------------------------------------------------------------------
|
|
889
|
+
// #14: Skill outdated check
|
|
890
|
+
// ---------------------------------------------------------------------------
|
|
891
|
+
|
|
892
|
+
async function cmdOutdated(json: boolean): Promise<number> {
|
|
893
|
+
const ids = await getActiveProfileSkillIds();
|
|
894
|
+
if (!ids.length) { process.stderr.write("No skills in active profile.\n"); return 1; }
|
|
895
|
+
|
|
896
|
+
const results: { id: string; lastModified: string; daysOld: number }[] = [];
|
|
897
|
+
const now = Date.now();
|
|
898
|
+
|
|
899
|
+
for (const id of ids) {
|
|
900
|
+
const skillPath = join(SKILLS_ROOT, id, "SKILL.md");
|
|
901
|
+
try {
|
|
902
|
+
const { statSync } = require("node:fs");
|
|
903
|
+
const stat = statSync(skillPath);
|
|
904
|
+
const daysOld = Math.floor((now - stat.mtimeMs) / 86400000);
|
|
905
|
+
results.push({ id, lastModified: stat.mtime.toISOString().slice(0, 10), daysOld });
|
|
906
|
+
} catch { /* skip */ }
|
|
907
|
+
}
|
|
908
|
+
|
|
909
|
+
const outdated = results.filter(r => r.daysOld > 30).sort((a, b) => b.daysOld - a.daysOld);
|
|
910
|
+
|
|
911
|
+
if (json) {
|
|
912
|
+
process.stdout.write(JSON.stringify({ total: results.length, outdated }, null, 2) + "\n");
|
|
913
|
+
return 0;
|
|
914
|
+
}
|
|
915
|
+
|
|
916
|
+
if (outdated.length === 0) {
|
|
917
|
+
process.stdout.write("✅ All skills updated within the last 30 days.\n");
|
|
918
|
+
return 0;
|
|
919
|
+
}
|
|
920
|
+
|
|
921
|
+
process.stdout.write(`⚠️ ${outdated.length} skill(s) outdated (>30 days since last update):\n\n`);
|
|
922
|
+
for (const r of outdated) {
|
|
923
|
+
process.stdout.write(` ${r.id.padEnd(40)} ${r.lastModified} (${r.daysOld} days)\n`);
|
|
924
|
+
}
|
|
925
|
+
process.stdout.write(`\nRun \`cue update --skills\` to sync from upstream.\n`);
|
|
926
|
+
return 0;
|
|
927
|
+
}
|
|
928
|
+
|
|
929
|
+
// ---------------------------------------------------------------------------
|
|
930
|
+
// Router
|
|
931
|
+
// ---------------------------------------------------------------------------
|
|
932
|
+
|
|
933
|
+
export async function run(args: string[]): Promise<number> {
|
|
934
|
+
if (args.includes("-h") || args.includes("--help")) {
|
|
935
|
+
process.stdout.write(`cue skills — manage skills in profiles
|
|
936
|
+
|
|
937
|
+
Usage: cue skills <subcommand> [args]
|
|
938
|
+
|
|
939
|
+
Subcommands:
|
|
940
|
+
list Skills in active profile
|
|
941
|
+
available Skills NOT in active profile
|
|
942
|
+
search <query> Fuzzy search all skills
|
|
943
|
+
add-to-profile <id> Add skill to active profile
|
|
944
|
+
remove-from-profile Remove skill from active profile
|
|
945
|
+
rank [limit] Usage leaderboard
|
|
946
|
+
audit Find unused skills
|
|
947
|
+
conflicts Detect contradicting skills
|
|
948
|
+
lint <id>|--all Quality check
|
|
949
|
+
test <id>|--all Run skill tests
|
|
950
|
+
new <cat/name> Scaffold a new skill
|
|
951
|
+
pin/rollback/unpin Version pinning
|
|
952
|
+
changelog <id> Show version history
|
|
953
|
+
rate <id> up|down Rate a skill
|
|
954
|
+
outdated Show stale skills
|
|
955
|
+
|
|
956
|
+
Examples:
|
|
957
|
+
cue skills search "review"
|
|
958
|
+
cue skills add-to-profile review/code-review
|
|
959
|
+
cue skills rank 20
|
|
960
|
+
`);
|
|
961
|
+
return 0;
|
|
962
|
+
}
|
|
963
|
+
|
|
964
|
+
const sub = args[0] ?? "list";
|
|
965
|
+
const json = args.includes("--json");
|
|
966
|
+
const rest = args.filter(a => a !== "--json");
|
|
967
|
+
|
|
968
|
+
switch (sub) {
|
|
969
|
+
case "list":
|
|
970
|
+
return cmdList(json);
|
|
971
|
+
case "available":
|
|
972
|
+
return cmdAvailable(json);
|
|
973
|
+
case "search":
|
|
974
|
+
return cmdSearch(rest.slice(1).join(" ") || "", json);
|
|
975
|
+
case "add-to-profile":
|
|
976
|
+
return cmdAddToProfile(rest[1] ?? "", args.includes("--preview"));
|
|
977
|
+
case "remove-from-profile":
|
|
978
|
+
return cmdRemoveFromProfile(rest[1] ?? "");
|
|
979
|
+
case "audit":
|
|
980
|
+
return cmdAudit(json);
|
|
981
|
+
case "conflicts":
|
|
982
|
+
return cmdConflicts(json);
|
|
983
|
+
case "changelog":
|
|
984
|
+
return cmdChangelog(rest[1] ?? "");
|
|
985
|
+
case "test": {
|
|
986
|
+
const { run: runTest } = await import("./skills-test");
|
|
987
|
+
return runTest(rest.slice(1));
|
|
988
|
+
}
|
|
989
|
+
case "lint": {
|
|
990
|
+
const { run: runLint } = await import("./skills-lint");
|
|
991
|
+
return runLint(rest.slice(1));
|
|
992
|
+
}
|
|
993
|
+
case "new": {
|
|
994
|
+
const { run: runNew } = await import("./skills-new");
|
|
995
|
+
return runNew(rest.slice(1));
|
|
996
|
+
}
|
|
997
|
+
case "pin":
|
|
998
|
+
case "rollback":
|
|
999
|
+
case "unpin": {
|
|
1000
|
+
const { run: runPin } = await import("./skills-pin");
|
|
1001
|
+
return runPin(rest);
|
|
1002
|
+
}
|
|
1003
|
+
case "rank":
|
|
1004
|
+
return cmdRank(rest.slice(1));
|
|
1005
|
+
case "rate":
|
|
1006
|
+
return cmdRate(rest[1] ?? "", rest[2] ?? "");
|
|
1007
|
+
case "outdated":
|
|
1008
|
+
return cmdOutdated(json);
|
|
1009
|
+
case "add":
|
|
1010
|
+
return cmdNpxAdd(args);
|
|
1011
|
+
default:
|
|
1012
|
+
return cmdNpxAdd(args);
|
|
1013
|
+
}
|
|
1014
|
+
}
|
|
1015
|
+
|
|
1016
|
+
// ---------------------------------------------------------------------------
|
|
1017
|
+
// #10: Skill audit — effectiveness scoring
|
|
1018
|
+
// ---------------------------------------------------------------------------
|
|
1019
|
+
|
|
1020
|
+
async function cmdAudit(json: boolean): Promise<number> {
|
|
1021
|
+
const { scoreSkills } = await import("../lib/skill-scorer");
|
|
1022
|
+
const ids = await getActiveProfileSkillIds();
|
|
1023
|
+
if (ids.length === 0) {
|
|
1024
|
+
process.stderr.write("No skills in active profile.\n");
|
|
1025
|
+
return 1;
|
|
1026
|
+
}
|
|
1027
|
+
|
|
1028
|
+
const results = scoreSkills(ids);
|
|
1029
|
+
|
|
1030
|
+
if (json) {
|
|
1031
|
+
process.stdout.write(JSON.stringify(results, null, 2) + "\n");
|
|
1032
|
+
return 0;
|
|
1033
|
+
}
|
|
1034
|
+
|
|
1035
|
+
const profileName = await getActiveProfileName();
|
|
1036
|
+
process.stdout.write(`Skill usage audit for "${profileName}" (last 20 sessions):\n\n`);
|
|
1037
|
+
for (const r of results) {
|
|
1038
|
+
const icon = r.references === 0 ? "❌" : r.references < 3 ? "⚠️" : "✅";
|
|
1039
|
+
process.stdout.write(` ${icon} ${r.id} — ${r.references} references\n`);
|
|
1040
|
+
}
|
|
1041
|
+
const dead = results.filter(r => r.references === 0);
|
|
1042
|
+
if (dead.length) {
|
|
1043
|
+
process.stdout.write(`\n ${dead.length} unused skill(s) — candidates for removal.\n`);
|
|
1044
|
+
}
|
|
1045
|
+
return 0;
|
|
1046
|
+
}
|
|
1047
|
+
|
|
1048
|
+
// ---------------------------------------------------------------------------
|
|
1049
|
+
// #18: Skill conflict detection
|
|
1050
|
+
// ---------------------------------------------------------------------------
|
|
1051
|
+
|
|
1052
|
+
async function cmdConflicts(json: boolean): Promise<number> {
|
|
1053
|
+
const { detectConflicts } = await import("../lib/conflict-detector");
|
|
1054
|
+
const ids = await getActiveProfileSkillIds();
|
|
1055
|
+
const conflicts = detectConflicts(ids);
|
|
1056
|
+
|
|
1057
|
+
if (json) {
|
|
1058
|
+
process.stdout.write(JSON.stringify(conflicts, null, 2) + "\n");
|
|
1059
|
+
return 0;
|
|
1060
|
+
}
|
|
1061
|
+
|
|
1062
|
+
if (conflicts.length === 0) {
|
|
1063
|
+
process.stdout.write("✅ No skill conflicts detected.\n");
|
|
1064
|
+
return 0;
|
|
1065
|
+
}
|
|
1066
|
+
|
|
1067
|
+
process.stdout.write(`⚠️ ${conflicts.length} potential conflict(s):\n\n`);
|
|
1068
|
+
for (const c of conflicts) {
|
|
1069
|
+
process.stdout.write(` ${c.skillA} vs ${c.skillB}\n`);
|
|
1070
|
+
process.stdout.write(` "${c.directiveA}"\n`);
|
|
1071
|
+
process.stdout.write(` conflicts with: "${c.directiveB}"\n\n`);
|
|
1072
|
+
}
|
|
1073
|
+
return 0;
|
|
1074
|
+
}
|
|
1075
|
+
|
|
1076
|
+
// ---------------------------------------------------------------------------
|
|
1077
|
+
// #13: Skill changelog
|
|
1078
|
+
// ---------------------------------------------------------------------------
|
|
1079
|
+
|
|
1080
|
+
function cmdChangelog(id: string): number {
|
|
1081
|
+
if (!id) {
|
|
1082
|
+
process.stderr.write("Usage: cue skills changelog <skill-id>\n");
|
|
1083
|
+
return 1;
|
|
1084
|
+
}
|
|
1085
|
+
|
|
1086
|
+
const meta = parseSkillMeta(id);
|
|
1087
|
+
const skillPath = join(SKILLS_ROOT, id, "SKILL.md");
|
|
1088
|
+
try {
|
|
1089
|
+
const content = readFileSync(skillPath, "utf8");
|
|
1090
|
+
const fmMatch = content.match(/^---\n([\s\S]*?)\n---/);
|
|
1091
|
+
if (!fmMatch) { process.stdout.write("No frontmatter found.\n"); return 0; }
|
|
1092
|
+
|
|
1093
|
+
const versionMatch = fmMatch[1]!.match(/^version:\s*(.+)$/m);
|
|
1094
|
+
const version = versionMatch?.[1] ?? "unknown";
|
|
1095
|
+
|
|
1096
|
+
// Extract changelog entries
|
|
1097
|
+
const changelogMatch = fmMatch[1]!.match(/^changelog:\s*\n((?:\s+-\s+.+\n?)*)/m);
|
|
1098
|
+
|
|
1099
|
+
process.stdout.write(`${id} v${version}\n\n`);
|
|
1100
|
+
if (changelogMatch) {
|
|
1101
|
+
const entries = changelogMatch[1]!.match(/^\s+-\s+"?(.+?)"?\s*$/gm);
|
|
1102
|
+
if (entries) {
|
|
1103
|
+
for (const e of entries) {
|
|
1104
|
+
process.stdout.write(` ${e.trim()}\n`);
|
|
1105
|
+
}
|
|
1106
|
+
}
|
|
1107
|
+
} else {
|
|
1108
|
+
process.stdout.write(" No changelog entries.\n");
|
|
1109
|
+
}
|
|
1110
|
+
} catch {
|
|
1111
|
+
process.stderr.write(`Skill "${id}" not found.\n`);
|
|
1112
|
+
return 1;
|
|
1113
|
+
}
|
|
1114
|
+
return 0;
|
|
1115
|
+
}
|