convex 1.34.0 → 1.34.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (243) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/browser.bundle.js +6 -9
  3. package/dist/browser.bundle.js.map +2 -2
  4. package/dist/cjs/browser/sync/authentication_manager.js +4 -1
  5. package/dist/cjs/browser/sync/authentication_manager.js.map +2 -2
  6. package/dist/cjs/browser/sync/web_socket_manager.js +1 -7
  7. package/dist/cjs/browser/sync/web_socket_manager.js.map +2 -2
  8. package/dist/cjs/cli/aiFiles.js +15 -14
  9. package/dist/cjs/cli/aiFiles.js.map +2 -2
  10. package/dist/cjs/cli/configure.js +15 -10
  11. package/dist/cjs/cli/configure.js.map +2 -2
  12. package/dist/cjs/cli/lib/aiFiles/agentsmd.js +69 -0
  13. package/dist/cjs/cli/lib/aiFiles/agentsmd.js.map +7 -0
  14. package/dist/cjs/cli/lib/aiFiles/claudemd.js +69 -0
  15. package/dist/cjs/cli/lib/aiFiles/claudemd.js.map +7 -0
  16. package/dist/cjs/cli/lib/{ai → aiFiles}/config.js +73 -46
  17. package/dist/cjs/cli/lib/aiFiles/config.js.map +7 -0
  18. package/dist/cjs/cli/lib/aiFiles/cursorrules.js +48 -0
  19. package/dist/cjs/cli/lib/aiFiles/cursorrules.js.map +7 -0
  20. package/dist/cjs/cli/lib/aiFiles/guidelinesmd.js +51 -0
  21. package/dist/cjs/cli/lib/aiFiles/guidelinesmd.js.map +7 -0
  22. package/dist/cjs/cli/lib/aiFiles/index.js +231 -0
  23. package/dist/cjs/cli/lib/aiFiles/index.js.map +7 -0
  24. package/dist/cjs/cli/lib/aiFiles/paths.js.map +7 -0
  25. package/dist/cjs/cli/lib/aiFiles/skills.js +180 -0
  26. package/dist/cjs/cli/lib/aiFiles/skills.js.map +7 -0
  27. package/dist/cjs/cli/lib/aiFiles/status.js +195 -0
  28. package/dist/cjs/cli/lib/aiFiles/status.js.map +7 -0
  29. package/dist/cjs/cli/lib/aiFiles/utils.js +111 -0
  30. package/dist/cjs/cli/lib/aiFiles/utils.js.map +7 -0
  31. package/dist/cjs/cli/lib/command.js +6 -1
  32. package/dist/cjs/cli/lib/command.js.map +2 -2
  33. package/dist/cjs/cli/lib/config.js +3 -4
  34. package/dist/cjs/cli/lib/config.js.map +2 -2
  35. package/dist/cjs/cli/lib/localDeployment/anonymous.js +2 -2
  36. package/dist/cjs/cli/lib/localDeployment/anonymous.js.map +2 -2
  37. package/dist/cjs/cli/lib/updates.js +8 -8
  38. package/dist/cjs/cli/lib/updates.js.map +2 -2
  39. package/dist/cjs/cli/lib/versionApi.js +7 -4
  40. package/dist/cjs/cli/lib/versionApi.js.map +2 -2
  41. package/dist/cjs/cli/lib/workos/workos.js +4 -6
  42. package/dist/cjs/cli/lib/workos/workos.js.map +2 -2
  43. package/dist/cjs/index.js +1 -1
  44. package/dist/cjs/index.js.map +1 -1
  45. package/dist/cjs-types/browser/sync/authentication_manager.d.ts.map +1 -1
  46. package/dist/cjs-types/browser/sync/web_socket_manager.d.ts.map +1 -1
  47. package/dist/cjs-types/cli/aiFiles.d.ts.map +1 -1
  48. package/dist/cjs-types/cli/configure.d.ts.map +1 -1
  49. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.d.ts +19 -0
  50. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.d.ts.map +1 -0
  51. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.test.d.ts +2 -0
  52. package/dist/cjs-types/cli/lib/aiFiles/agentsmd.test.d.ts.map +1 -0
  53. package/dist/cjs-types/cli/lib/aiFiles/claudemd.d.ts +19 -0
  54. package/dist/cjs-types/cli/lib/aiFiles/claudemd.d.ts.map +1 -0
  55. package/dist/cjs-types/cli/lib/aiFiles/claudemd.test.d.ts +2 -0
  56. package/dist/cjs-types/cli/lib/aiFiles/claudemd.test.d.ts.map +1 -0
  57. package/dist/cjs-types/cli/lib/aiFiles/config.d.ts +46 -0
  58. package/dist/cjs-types/cli/lib/aiFiles/config.d.ts.map +1 -0
  59. package/dist/cjs-types/cli/lib/aiFiles/config.test.d.ts.map +1 -0
  60. package/dist/cjs-types/cli/lib/aiFiles/cursorrules.d.ts +10 -0
  61. package/dist/cjs-types/cli/lib/aiFiles/cursorrules.d.ts.map +1 -0
  62. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.d.ts +12 -0
  63. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.d.ts.map +1 -0
  64. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.test.d.ts +2 -0
  65. package/dist/cjs-types/cli/lib/aiFiles/guidelinesmd.test.d.ts.map +1 -0
  66. package/dist/cjs-types/cli/lib/aiFiles/index.d.ts +40 -0
  67. package/dist/cjs-types/cli/lib/aiFiles/index.d.ts.map +1 -0
  68. package/dist/cjs-types/cli/lib/aiFiles/index.test.d.ts.map +1 -0
  69. package/dist/cjs-types/cli/lib/aiFiles/integration.test.d.ts.map +1 -0
  70. package/dist/cjs-types/cli/lib/{ai → aiFiles}/paths.d.ts +4 -0
  71. package/dist/cjs-types/cli/lib/aiFiles/paths.d.ts.map +1 -0
  72. package/dist/cjs-types/cli/lib/aiFiles/prompt.test.d.ts.map +1 -0
  73. package/dist/cjs-types/cli/lib/aiFiles/skills.d.ts +18 -0
  74. package/dist/cjs-types/cli/lib/aiFiles/skills.d.ts.map +1 -0
  75. package/dist/cjs-types/cli/lib/aiFiles/status.d.ts +3 -0
  76. package/dist/cjs-types/cli/lib/aiFiles/status.d.ts.map +1 -0
  77. package/dist/cjs-types/cli/lib/aiFiles/utils.d.ts +46 -0
  78. package/dist/cjs-types/cli/lib/aiFiles/utils.d.ts.map +1 -0
  79. package/dist/cjs-types/cli/lib/config.d.ts +1 -0
  80. package/dist/cjs-types/cli/lib/config.d.ts.map +1 -1
  81. package/dist/cjs-types/cli/lib/versionApi.d.ts +7 -1
  82. package/dist/cjs-types/cli/lib/versionApi.d.ts.map +1 -1
  83. package/dist/cjs-types/cli/lib/workos/workos.d.ts.map +1 -1
  84. package/dist/cjs-types/index.d.ts +1 -1
  85. package/dist/cli.bundle.cjs +1605 -1548
  86. package/dist/cli.bundle.cjs.map +4 -4
  87. package/dist/esm/browser/sync/authentication_manager.js +4 -1
  88. package/dist/esm/browser/sync/authentication_manager.js.map +2 -2
  89. package/dist/esm/browser/sync/web_socket_manager.js +1 -7
  90. package/dist/esm/browser/sync/web_socket_manager.js.map +2 -2
  91. package/dist/esm/cli/aiFiles.js +17 -17
  92. package/dist/esm/cli/aiFiles.js.map +2 -2
  93. package/dist/esm/cli/configure.js +15 -10
  94. package/dist/esm/cli/configure.js.map +2 -2
  95. package/dist/esm/cli/lib/aiFiles/agentsmd.js +52 -0
  96. package/dist/esm/cli/lib/aiFiles/agentsmd.js.map +7 -0
  97. package/dist/esm/cli/lib/aiFiles/claudemd.js +52 -0
  98. package/dist/esm/cli/lib/aiFiles/claudemd.js.map +7 -0
  99. package/dist/esm/cli/lib/{ai → aiFiles}/config.js +71 -45
  100. package/dist/esm/cli/lib/aiFiles/config.js.map +7 -0
  101. package/dist/esm/cli/lib/aiFiles/cursorrules.js +16 -0
  102. package/dist/esm/cli/lib/aiFiles/cursorrules.js.map +7 -0
  103. package/dist/esm/cli/lib/aiFiles/guidelinesmd.js +28 -0
  104. package/dist/esm/cli/lib/aiFiles/guidelinesmd.js.map +7 -0
  105. package/dist/esm/cli/lib/aiFiles/index.js +210 -0
  106. package/dist/esm/cli/lib/aiFiles/index.js.map +7 -0
  107. package/dist/esm/cli/lib/aiFiles/paths.js.map +7 -0
  108. package/dist/esm/cli/lib/aiFiles/skills.js +147 -0
  109. package/dist/esm/cli/lib/aiFiles/skills.js.map +7 -0
  110. package/dist/esm/cli/lib/aiFiles/status.js +175 -0
  111. package/dist/esm/cli/lib/aiFiles/status.js.map +7 -0
  112. package/dist/esm/cli/lib/aiFiles/utils.js +82 -0
  113. package/dist/esm/cli/lib/aiFiles/utils.js.map +7 -0
  114. package/dist/esm/cli/lib/command.js +6 -1
  115. package/dist/esm/cli/lib/command.js.map +2 -2
  116. package/dist/esm/cli/lib/config.js +3 -4
  117. package/dist/esm/cli/lib/config.js.map +2 -2
  118. package/dist/esm/cli/lib/localDeployment/anonymous.js +2 -2
  119. package/dist/esm/cli/lib/localDeployment/anonymous.js.map +2 -2
  120. package/dist/esm/cli/lib/updates.js +8 -8
  121. package/dist/esm/cli/lib/updates.js.map +2 -2
  122. package/dist/esm/cli/lib/versionApi.js +7 -4
  123. package/dist/esm/cli/lib/versionApi.js.map +2 -2
  124. package/dist/esm/cli/lib/workos/workos.js +4 -6
  125. package/dist/esm/cli/lib/workos/workos.js.map +2 -2
  126. package/dist/esm/index.js +1 -1
  127. package/dist/esm/index.js.map +1 -1
  128. package/dist/esm-types/browser/sync/authentication_manager.d.ts.map +1 -1
  129. package/dist/esm-types/browser/sync/web_socket_manager.d.ts.map +1 -1
  130. package/dist/esm-types/cli/aiFiles.d.ts.map +1 -1
  131. package/dist/esm-types/cli/configure.d.ts.map +1 -1
  132. package/dist/esm-types/cli/lib/aiFiles/agentsmd.d.ts +19 -0
  133. package/dist/esm-types/cli/lib/aiFiles/agentsmd.d.ts.map +1 -0
  134. package/dist/esm-types/cli/lib/aiFiles/agentsmd.test.d.ts +2 -0
  135. package/dist/esm-types/cli/lib/aiFiles/agentsmd.test.d.ts.map +1 -0
  136. package/dist/esm-types/cli/lib/aiFiles/claudemd.d.ts +19 -0
  137. package/dist/esm-types/cli/lib/aiFiles/claudemd.d.ts.map +1 -0
  138. package/dist/esm-types/cli/lib/aiFiles/claudemd.test.d.ts +2 -0
  139. package/dist/esm-types/cli/lib/aiFiles/claudemd.test.d.ts.map +1 -0
  140. package/dist/esm-types/cli/lib/aiFiles/config.d.ts +46 -0
  141. package/dist/esm-types/cli/lib/aiFiles/config.d.ts.map +1 -0
  142. package/dist/esm-types/cli/lib/aiFiles/config.test.d.ts.map +1 -0
  143. package/dist/esm-types/cli/lib/aiFiles/cursorrules.d.ts +10 -0
  144. package/dist/esm-types/cli/lib/aiFiles/cursorrules.d.ts.map +1 -0
  145. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.d.ts +12 -0
  146. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.d.ts.map +1 -0
  147. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.test.d.ts +2 -0
  148. package/dist/esm-types/cli/lib/aiFiles/guidelinesmd.test.d.ts.map +1 -0
  149. package/dist/esm-types/cli/lib/aiFiles/index.d.ts +40 -0
  150. package/dist/esm-types/cli/lib/aiFiles/index.d.ts.map +1 -0
  151. package/dist/esm-types/cli/lib/aiFiles/index.test.d.ts.map +1 -0
  152. package/dist/esm-types/cli/lib/aiFiles/integration.test.d.ts.map +1 -0
  153. package/dist/esm-types/cli/lib/{ai → aiFiles}/paths.d.ts +4 -0
  154. package/dist/esm-types/cli/lib/aiFiles/paths.d.ts.map +1 -0
  155. package/dist/esm-types/cli/lib/aiFiles/prompt.test.d.ts.map +1 -0
  156. package/dist/esm-types/cli/lib/aiFiles/skills.d.ts +18 -0
  157. package/dist/esm-types/cli/lib/aiFiles/skills.d.ts.map +1 -0
  158. package/dist/esm-types/cli/lib/aiFiles/status.d.ts +3 -0
  159. package/dist/esm-types/cli/lib/aiFiles/status.d.ts.map +1 -0
  160. package/dist/esm-types/cli/lib/aiFiles/utils.d.ts +46 -0
  161. package/dist/esm-types/cli/lib/aiFiles/utils.d.ts.map +1 -0
  162. package/dist/esm-types/cli/lib/config.d.ts +1 -0
  163. package/dist/esm-types/cli/lib/config.d.ts.map +1 -1
  164. package/dist/esm-types/cli/lib/versionApi.d.ts +7 -1
  165. package/dist/esm-types/cli/lib/versionApi.d.ts.map +1 -1
  166. package/dist/esm-types/cli/lib/workos/workos.d.ts.map +1 -1
  167. package/dist/esm-types/index.d.ts +1 -1
  168. package/dist/react.bundle.js +6 -9
  169. package/dist/react.bundle.js.map +2 -2
  170. package/package.json +1 -1
  171. package/schemas/convex.schema.json +7 -1
  172. package/src/browser/sync/authentication_manager.ts +9 -4
  173. package/src/browser/sync/client_node.test.ts +125 -0
  174. package/src/browser/sync/web_socket_manager.ts +1 -7
  175. package/src/cli/aiFiles.ts +20 -27
  176. package/src/cli/configure.ts +17 -11
  177. package/src/cli/deploymentSelection.test.ts +56 -2
  178. package/src/cli/lib/{ai → aiFiles}/MANUAL_TESTING.md +6 -2
  179. package/src/cli/lib/aiFiles/agentsmd.test.ts +133 -0
  180. package/src/cli/lib/aiFiles/agentsmd.ts +77 -0
  181. package/src/cli/lib/aiFiles/claudemd.test.ts +92 -0
  182. package/src/cli/lib/aiFiles/claudemd.ts +77 -0
  183. package/src/cli/lib/{ai → aiFiles}/config.test.ts +181 -59
  184. package/src/cli/lib/{ai → aiFiles}/config.ts +92 -63
  185. package/src/cli/lib/aiFiles/cursorrules.ts +25 -0
  186. package/src/cli/lib/aiFiles/guidelinesmd.test.ts +40 -0
  187. package/src/cli/lib/aiFiles/guidelinesmd.ts +41 -0
  188. package/src/cli/lib/{ai → aiFiles}/index.test.ts +200 -339
  189. package/src/cli/lib/aiFiles/index.ts +303 -0
  190. package/src/cli/lib/{ai → aiFiles}/integration.test.ts +117 -147
  191. package/src/cli/lib/{ai → aiFiles}/paths.ts +5 -0
  192. package/src/cli/lib/{ai → aiFiles}/prompt.test.ts +78 -30
  193. package/src/cli/lib/aiFiles/skills.ts +213 -0
  194. package/src/cli/lib/aiFiles/status.ts +240 -0
  195. package/src/cli/lib/aiFiles/utils.ts +163 -0
  196. package/src/cli/lib/command.ts +6 -1
  197. package/src/cli/lib/config.test.ts +1 -1
  198. package/src/cli/lib/config.ts +6 -5
  199. package/src/cli/lib/localDeployment/anonymous.ts +2 -2
  200. package/src/cli/lib/updates.test.ts +40 -30
  201. package/src/cli/lib/updates.ts +8 -8
  202. package/src/cli/lib/versionApi.test.ts +13 -10
  203. package/src/cli/lib/versionApi.ts +13 -5
  204. package/src/cli/lib/workos/workos.ts +4 -5
  205. package/src/index.ts +1 -1
  206. package/src/values/.claude/settings.local.json +10 -0
  207. package/dist/cjs/cli/lib/ai/config.js.map +0 -7
  208. package/dist/cjs/cli/lib/ai/index.js +0 -704
  209. package/dist/cjs/cli/lib/ai/index.js.map +0 -7
  210. package/dist/cjs/cli/lib/ai/paths.js.map +0 -7
  211. package/dist/cjs-types/cli/lib/ai/config.d.ts +0 -50
  212. package/dist/cjs-types/cli/lib/ai/config.d.ts.map +0 -1
  213. package/dist/cjs-types/cli/lib/ai/config.test.d.ts.map +0 -1
  214. package/dist/cjs-types/cli/lib/ai/index.d.ts +0 -56
  215. package/dist/cjs-types/cli/lib/ai/index.d.ts.map +0 -1
  216. package/dist/cjs-types/cli/lib/ai/index.test.d.ts.map +0 -1
  217. package/dist/cjs-types/cli/lib/ai/integration.test.d.ts.map +0 -1
  218. package/dist/cjs-types/cli/lib/ai/paths.d.ts.map +0 -1
  219. package/dist/cjs-types/cli/lib/ai/prompt.test.d.ts.map +0 -1
  220. package/dist/esm/cli/lib/ai/config.js.map +0 -7
  221. package/dist/esm/cli/lib/ai/index.js +0 -684
  222. package/dist/esm/cli/lib/ai/index.js.map +0 -7
  223. package/dist/esm/cli/lib/ai/paths.js.map +0 -7
  224. package/dist/esm-types/cli/lib/ai/config.d.ts +0 -50
  225. package/dist/esm-types/cli/lib/ai/config.d.ts.map +0 -1
  226. package/dist/esm-types/cli/lib/ai/config.test.d.ts.map +0 -1
  227. package/dist/esm-types/cli/lib/ai/index.d.ts +0 -56
  228. package/dist/esm-types/cli/lib/ai/index.d.ts.map +0 -1
  229. package/dist/esm-types/cli/lib/ai/index.test.d.ts.map +0 -1
  230. package/dist/esm-types/cli/lib/ai/integration.test.d.ts.map +0 -1
  231. package/dist/esm-types/cli/lib/ai/paths.d.ts.map +0 -1
  232. package/dist/esm-types/cli/lib/ai/prompt.test.d.ts.map +0 -1
  233. package/src/cli/lib/ai/index.ts +0 -1006
  234. /package/dist/cjs/cli/lib/{ai → aiFiles}/paths.js +0 -0
  235. /package/dist/cjs-types/cli/lib/{ai → aiFiles}/config.test.d.ts +0 -0
  236. /package/dist/cjs-types/cli/lib/{ai → aiFiles}/index.test.d.ts +0 -0
  237. /package/dist/cjs-types/cli/lib/{ai → aiFiles}/integration.test.d.ts +0 -0
  238. /package/dist/cjs-types/cli/lib/{ai → aiFiles}/prompt.test.d.ts +0 -0
  239. /package/dist/esm/cli/lib/{ai → aiFiles}/paths.js +0 -0
  240. /package/dist/esm-types/cli/lib/{ai → aiFiles}/config.test.d.ts +0 -0
  241. /package/dist/esm-types/cli/lib/{ai → aiFiles}/index.test.d.ts +0 -0
  242. /package/dist/esm-types/cli/lib/{ai → aiFiles}/integration.test.d.ts +0 -0
  243. /package/dist/esm-types/cli/lib/{ai → aiFiles}/prompt.test.d.ts +0 -0
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var guidelinesmd_exports = {};
20
+ __export(guidelinesmd_exports, {
21
+ hasGuidelinesInstalled: () => hasGuidelinesInstalled,
22
+ installGuidelinesFile: () => installGuidelinesFile
23
+ });
24
+ module.exports = __toCommonJS(guidelinesmd_exports);
25
+ var import_fs = require("fs");
26
+ var import_chalk = require("chalk");
27
+ var import_log = require("../../../bundler/log.js");
28
+ var import_versionApi = require("../versionApi.js");
29
+ var import_hash = require("../utils/hash.js");
30
+ var import_paths = require("./paths.js");
31
+ var import_utils = require("./utils.js");
32
+ async function hasGuidelinesInstalled(convexDir) {
33
+ return await (0, import_utils.readFileSafe)((0, import_paths.guidelinesPathForConvexDir)(convexDir)) !== null;
34
+ }
35
+ async function installGuidelinesFile({
36
+ convexDir,
37
+ config
38
+ }) {
39
+ const guidelines = await (0, import_versionApi.downloadGuidelines)();
40
+ if (guidelines === null) {
41
+ (0, import_log.logMessage)(
42
+ import_chalk.chalkStderr.yellow(
43
+ "Could not download Convex AI guidelines right now. You can retry with: npx convex ai-files install"
44
+ )
45
+ );
46
+ return;
47
+ }
48
+ await import_fs.promises.writeFile((0, import_paths.guidelinesPathForConvexDir)(convexDir), guidelines, "utf8");
49
+ config.guidelinesHash = (0, import_hash.hashSha256)(guidelines);
50
+ }
51
+ //# sourceMappingURL=guidelinesmd.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/cli/lib/aiFiles/guidelinesmd.ts"],
4
+ "sourcesContent": ["// eslint-disable-next-line no-restricted-imports\nimport { promises as fs } from \"fs\";\nimport { chalkStderr } from \"chalk\";\nimport { logMessage } from \"../../../bundler/log.js\";\nimport { downloadGuidelines } from \"../versionApi.js\";\nimport { hashSha256 } from \"../utils/hash.js\";\nimport { guidelinesPathForConvexDir } from \"./paths.js\";\nimport { readFileSafe } from \"./utils.js\";\nimport { type AiFilesConfig } from \"./config.js\";\n\nexport async function hasGuidelinesInstalled(\n convexDir: string,\n): Promise<boolean> {\n return (await readFileSafe(guidelinesPathForConvexDir(convexDir))) !== null;\n}\n\n/**\n * Download and write the guidelines file.\n * Guidelines live in `_generated/` so local edits are not expected and are\n * not preserved.\n */\nexport async function installGuidelinesFile({\n convexDir,\n config,\n}: {\n convexDir: string;\n config: AiFilesConfig;\n}): Promise<void> {\n const guidelines = await downloadGuidelines();\n if (guidelines === null) {\n logMessage(\n chalkStderr.yellow(\n \"Could not download Convex AI guidelines right now. You can retry with: npx convex ai-files install\",\n ),\n );\n return;\n }\n\n await fs.writeFile(guidelinesPathForConvexDir(convexDir), guidelines, \"utf8\");\n config.guidelinesHash = hashSha256(guidelines);\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,gBAA+B;AAC/B,mBAA4B;AAC5B,iBAA2B;AAC3B,wBAAmC;AACnC,kBAA2B;AAC3B,mBAA2C;AAC3C,mBAA6B;AAG7B,eAAsB,uBACpB,WACkB;AAClB,SAAQ,UAAM,+BAAa,yCAA2B,SAAS,CAAC,MAAO;AACzE;AAOA,eAAsB,sBAAsB;AAAA,EAC1C;AAAA,EACA;AACF,GAGkB;AAChB,QAAM,aAAa,UAAM,sCAAmB;AAC5C,MAAI,eAAe,MAAM;AACvB;AAAA,MACE,yBAAY;AAAA,QACV;AAAA,MACF;AAAA,IACF;AACA;AAAA,EACF;AAEA,QAAM,UAAAA,SAAG,cAAU,yCAA2B,SAAS,GAAG,YAAY,MAAM;AAC5E,SAAO,qBAAiB,wBAAW,UAAU;AAC/C;",
6
+ "names": ["fs"]
7
+ }
@@ -0,0 +1,231 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var aiFiles_exports = {};
30
+ __export(aiFiles_exports, {
31
+ checkAiFilesStaleness: () => checkAiFilesStaleness,
32
+ enableAiFiles: () => enableAiFiles,
33
+ installAiFiles: () => installAiFiles,
34
+ maybeSetupAiFiles: () => maybeSetupAiFiles,
35
+ removeAiFiles: () => removeAiFiles,
36
+ safelyAttemptToDisableAiFiles: () => safelyAttemptToDisableAiFiles
37
+ });
38
+ module.exports = __toCommonJS(aiFiles_exports);
39
+ var Sentry = __toESM(require("@sentry/node"), 1);
40
+ var import_path = __toESM(require("path"), 1);
41
+ var import_fs = require("fs");
42
+ var import_chalk = require("chalk");
43
+ var import_log = require("../../../bundler/log.js");
44
+ var import_prompts = require("../utils/prompts.js");
45
+ var import_paths = require("./paths.js");
46
+ var import_guidelinesmd = require("./guidelinesmd.js");
47
+ var import_config = require("./config.js");
48
+ var import_utils = require("./utils.js");
49
+ var import_agentsmd = require("./agentsmd.js");
50
+ var import_claudemd = require("./claudemd.js");
51
+ var import_skills = require("./skills.js");
52
+ var import_cursorrules = require("./cursorrules.js");
53
+ async function hasExistingAiFilesArtifacts({
54
+ projectDir,
55
+ convexDir
56
+ }) {
57
+ return await (0, import_guidelinesmd.hasGuidelinesInstalled)(convexDir) || await (0, import_agentsmd.hasAgentsMdInstalled)(projectDir) || await (0, import_claudemd.hasClaudeMdInstalled)(projectDir);
58
+ }
59
+ async function installAiFiles({
60
+ projectDir,
61
+ convexDir,
62
+ shouldWriteGuidelines = true,
63
+ shouldWriteAgentsMd = true,
64
+ shouldWriteClaudeMd = true,
65
+ shouldWriteSkills = true
66
+ }) {
67
+ await import_fs.promises.mkdir((0, import_paths.aiDirForConvexDir)(convexDir), { recursive: true });
68
+ const config = await (0, import_config.readAiConfig)({
69
+ projectDir,
70
+ convexDir
71
+ }) ?? {
72
+ enabled: true,
73
+ guidelinesHash: null,
74
+ agentsMdSectionHash: null,
75
+ claudeMdHash: null,
76
+ agentSkillsSha: null,
77
+ installedSkillNames: []
78
+ };
79
+ if (shouldWriteGuidelines) await (0, import_guidelinesmd.installGuidelinesFile)({ convexDir, config });
80
+ const convexDirName = import_path.default.relative(projectDir, convexDir);
81
+ if (shouldWriteAgentsMd)
82
+ await (0, import_agentsmd.applyAgentsMdSection)({ projectDir, config, convexDirName });
83
+ if (shouldWriteClaudeMd)
84
+ await (0, import_claudemd.applyClaudeMdSection)({ projectDir, config, convexDirName });
85
+ if (shouldWriteSkills) await (0, import_skills.installSkills)({ projectDir, config });
86
+ await (0, import_cursorrules.removeLegacyCursorRulesFile)(projectDir);
87
+ await (0, import_config.writeAiConfig)({ config, projectDir, convexDir });
88
+ (0, import_log.logMessage)(`${import_chalk.chalkStderr.green("\u2714")} Convex AI files installed.`);
89
+ }
90
+ async function attemptToInstallAiFiles(opts) {
91
+ try {
92
+ await installAiFiles(opts);
93
+ } catch (error) {
94
+ Sentry.captureException(error);
95
+ }
96
+ }
97
+ async function determineAiFilesStaleness({
98
+ canonicalGuidelinesHash,
99
+ canonicalAgentSkillsSha,
100
+ projectDir,
101
+ convexDir
102
+ }) {
103
+ const config = await (0, import_config.readAiConfig)({ projectDir, convexDir });
104
+ if (config === null) {
105
+ const hasArtifacts = await hasExistingAiFilesArtifacts({
106
+ projectDir,
107
+ convexDir
108
+ });
109
+ return hasArtifacts ? "has-artifacts" : "not-installed";
110
+ }
111
+ if (!config.enabled) return "disabled";
112
+ if (canonicalGuidelinesHash === null && canonicalAgentSkillsSha === null)
113
+ return "up-to-date";
114
+ const guidelinesStale = canonicalGuidelinesHash !== null && config.guidelinesHash !== null && config.guidelinesHash !== canonicalGuidelinesHash;
115
+ const skillsStale = canonicalAgentSkillsSha !== null && config.agentSkillsSha !== null && config.agentSkillsSha !== canonicalAgentSkillsSha;
116
+ return guidelinesStale || skillsStale ? "stale" : "up-to-date";
117
+ }
118
+ async function checkAiFilesStaleness(opts) {
119
+ const status = await determineAiFilesStaleness(opts);
120
+ if (status === "not-installed") {
121
+ (0, import_log.logMessage)(
122
+ import_chalk.chalkStderr.yellow(
123
+ `Convex AI files are not installed. Run ${import_chalk.chalkStderr.bold(`npx convex ai-files install`)} to get started or ${import_chalk.chalkStderr.bold(`npx convex ai-files disable`)} to hide this message.`
124
+ )
125
+ );
126
+ }
127
+ if (status === "stale") {
128
+ (0, import_log.logMessage)(
129
+ import_chalk.chalkStderr.yellow(
130
+ `Your Convex AI files are out of date. Run ${import_chalk.chalkStderr.bold(`npx convex ai-files update`)} to get the latest.`
131
+ )
132
+ );
133
+ }
134
+ }
135
+ async function enableAiFiles({
136
+ projectDir,
137
+ convexDir
138
+ }) {
139
+ await installAiFiles({ projectDir, convexDir });
140
+ const config = await (0, import_config.readAiConfig)({ projectDir, convexDir });
141
+ if (config === null) return;
142
+ config.enabled = true;
143
+ await (0, import_config.writeAiConfig)({
144
+ config,
145
+ projectDir,
146
+ convexDir,
147
+ options: { persistEnabledPreference: "always" }
148
+ });
149
+ }
150
+ async function removeAiFiles({
151
+ projectDir,
152
+ convexDir
153
+ }) {
154
+ const config = await (0, import_config.readAiConfig)({ projectDir, convexDir });
155
+ if (config === null) {
156
+ (0, import_log.logMessage)("No Convex AI files found \u2014 nothing to remove.");
157
+ return;
158
+ }
159
+ const removals = [
160
+ await (0, import_agentsmd.removeAgentsMdSection)(projectDir),
161
+ await (0, import_claudemd.removeClaudeMdSection)(projectDir),
162
+ await (0, import_skills.removeInstalledSkills)({
163
+ projectDir,
164
+ skillNames: config.installedSkillNames
165
+ }),
166
+ await (0, import_cursorrules.removeLegacyCursorRulesFile)(projectDir),
167
+ await attemptToDeleteAiDir({ projectDir, convexDir })
168
+ ];
169
+ if (removals.some(Boolean)) (0, import_log.logMessage)("Convex AI files removed.");
170
+ }
171
+ async function safelyAttemptToDisableAiFiles(projectDir) {
172
+ try {
173
+ await (0, import_config.writeAiEnabledToProjectConfig)({
174
+ projectDir,
175
+ enabled: false
176
+ });
177
+ (0, import_log.logMessage)(
178
+ `${import_chalk.chalkStderr.green(`\u2714`)} Convex AI files disabled. Run ${import_chalk.chalkStderr.bold(`npx convex ai-files enable`)} to re-enable.`
179
+ );
180
+ } catch (error) {
181
+ Sentry.captureException(error);
182
+ (0, import_log.logMessage)(
183
+ import_chalk.chalkStderr.yellow(
184
+ "Could not write AI message suppression config. Message may reappear."
185
+ )
186
+ );
187
+ }
188
+ }
189
+ async function attemptToDeleteAiDir({
190
+ projectDir,
191
+ convexDir
192
+ }) {
193
+ const aiDir = (0, import_paths.aiDirForConvexDir)(convexDir);
194
+ const relPath = import_path.default.relative(projectDir, aiDir);
195
+ try {
196
+ await import_fs.promises.rm(aiDir, { recursive: true, force: true });
197
+ (0, import_log.logMessage)(`${import_chalk.chalkStderr.green("\u2714")} Deleted ${relPath}/`);
198
+ return true;
199
+ } catch (error) {
200
+ Sentry.captureException(error);
201
+ (0, import_log.logMessage)(
202
+ import_chalk.chalkStderr.yellow(`Could not delete ${relPath}/. Remove it manually.`)
203
+ );
204
+ return false;
205
+ }
206
+ }
207
+ async function hasAiFilesBeenInstalledBefore({
208
+ projectDir,
209
+ convexDir
210
+ }) {
211
+ return await (0, import_config.hasAiFilesConfig)({ projectDir, convexDir }) || await hasExistingAiFilesArtifacts({ projectDir, convexDir });
212
+ }
213
+ async function maybeSetupAiFiles({
214
+ ctx,
215
+ convexDir,
216
+ projectDir
217
+ }) {
218
+ if (!(0, import_utils.isInInteractiveTerminal)()) return;
219
+ const config = await (0, import_config.readAiConfig)({ projectDir, convexDir });
220
+ if (config !== null && !config.enabled) return;
221
+ if (await hasAiFilesBeenInstalledBefore({ projectDir, convexDir })) {
222
+ await attemptToInstallAiFiles({ projectDir, convexDir });
223
+ return;
224
+ }
225
+ const shouldInstall = await (0, import_prompts.promptYesNo)(ctx, {
226
+ message: "Set up Convex AI files? (guidelines, AGENTS.md, agent skills)",
227
+ default: true
228
+ });
229
+ if (shouldInstall) await attemptToInstallAiFiles({ projectDir, convexDir });
230
+ }
231
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/cli/lib/aiFiles/index.ts"],
4
+ "sourcesContent": ["import * as Sentry from \"@sentry/node\";\nimport path from \"path\";\nimport { Context } from \"../../../bundler/context.js\";\n// eslint-disable-next-line no-restricted-imports\nimport { promises as fs } from \"fs\";\nimport { chalkStderr } from \"chalk\";\nimport { logMessage } from \"../../../bundler/log.js\";\nimport { promptYesNo } from \"../utils/prompts.js\";\nimport { type AiFilesPaths, aiDirForConvexDir } from \"./paths.js\";\nimport {\n installGuidelinesFile,\n hasGuidelinesInstalled,\n} from \"./guidelinesmd.js\";\nimport {\n type AiFilesConfig,\n hasAiFilesConfig,\n readAiConfig,\n writeAiConfig,\n writeAiEnabledToProjectConfig,\n} from \"./config.js\";\nimport { isInInteractiveTerminal } from \"./utils.js\";\nimport {\n hasAgentsMdInstalled,\n applyAgentsMdSection,\n removeAgentsMdSection,\n} from \"./agentsmd.js\";\nimport {\n hasClaudeMdInstalled,\n applyClaudeMdSection,\n removeClaudeMdSection,\n} from \"./claudemd.js\";\nimport { installSkills, removeInstalledSkills } from \"./skills.js\";\nimport { removeLegacyCursorRulesFile as removeLegacyCursorRules } from \"./cursorrules.js\";\nasync function hasExistingAiFilesArtifacts({\n projectDir,\n convexDir,\n}: AiFilesPaths): Promise<boolean> {\n return (\n (await hasGuidelinesInstalled(convexDir)) ||\n (await hasAgentsMdInstalled(projectDir)) ||\n (await hasClaudeMdInstalled(projectDir))\n );\n}\n\n/**\n * Install or refresh all Convex AI files.\n *\n * Reads the existing config if present, or starts from a blank one for a\n * fresh install. Each component can be individually skipped via the optional\n * flags (all default to true).\n */\nexport async function installAiFiles({\n projectDir,\n convexDir,\n shouldWriteGuidelines = true,\n shouldWriteAgentsMd = true,\n shouldWriteClaudeMd = true,\n shouldWriteSkills = true,\n}: AiFilesPaths & {\n shouldWriteGuidelines?: boolean;\n shouldWriteAgentsMd?: boolean;\n shouldWriteClaudeMd?: boolean;\n shouldWriteSkills?: boolean;\n}): Promise<void> {\n await fs.mkdir(aiDirForConvexDir(convexDir), { recursive: true });\n\n const config: AiFilesConfig = (await readAiConfig({\n projectDir,\n convexDir,\n })) ?? {\n enabled: true,\n guidelinesHash: null,\n agentsMdSectionHash: null,\n claudeMdHash: null,\n agentSkillsSha: null,\n installedSkillNames: [],\n };\n\n if (shouldWriteGuidelines) await installGuidelinesFile({ convexDir, config });\n\n const convexDirName = path.relative(projectDir, convexDir);\n\n if (shouldWriteAgentsMd)\n await applyAgentsMdSection({ projectDir, config, convexDirName });\n\n if (shouldWriteClaudeMd)\n await applyClaudeMdSection({ projectDir, config, convexDirName });\n\n if (shouldWriteSkills) await installSkills({ projectDir, config });\n\n await removeLegacyCursorRules(projectDir);\n await writeAiConfig({ config, projectDir, convexDir });\n\n logMessage(`${chalkStderr.green(\"\u2714\")} Convex AI files installed.`);\n}\n\nasync function attemptToInstallAiFiles(\n opts: Parameters<typeof installAiFiles>[0],\n): Promise<void> {\n try {\n await installAiFiles(opts);\n } catch (error) {\n Sentry.captureException(error);\n }\n}\n\ntype AiFilesStalenessStatus =\n | \"not-installed\" // no config AND no artifacts \u2014 show install nag\n | \"has-artifacts\" // no config but files exist on disk (e.g. fresh checkout) \u2014 stay quiet\n | \"disabled\" // user opted out of nag messages\n | \"stale\" // one or more files are out of date\n | \"up-to-date\"; // everything looks fine\n\nasync function determineAiFilesStaleness({\n canonicalGuidelinesHash,\n canonicalAgentSkillsSha,\n projectDir,\n convexDir,\n}: {\n canonicalGuidelinesHash: string | null;\n canonicalAgentSkillsSha: string | null;\n} & AiFilesPaths): Promise<AiFilesStalenessStatus> {\n const config = await readAiConfig({ projectDir, convexDir });\n\n if (config === null) {\n const hasArtifacts = await hasExistingAiFilesArtifacts({\n projectDir,\n convexDir,\n });\n return hasArtifacts ? \"has-artifacts\" : \"not-installed\";\n }\n\n if (!config.enabled) return \"disabled\";\n\n if (canonicalGuidelinesHash === null && canonicalAgentSkillsSha === null)\n return \"up-to-date\";\n\n const guidelinesStale =\n canonicalGuidelinesHash !== null &&\n config.guidelinesHash !== null &&\n config.guidelinesHash !== canonicalGuidelinesHash;\n\n const skillsStale =\n canonicalAgentSkillsSha !== null &&\n config.agentSkillsSha !== null &&\n config.agentSkillsSha !== canonicalAgentSkillsSha;\n\n return guidelinesStale || skillsStale ? \"stale\" : \"up-to-date\";\n}\n\n/**\n * Check whether the Convex AI files are out of date and log a nag message\n * if so.\n */\nexport async function checkAiFilesStaleness(\n opts: {\n canonicalGuidelinesHash: string | null;\n canonicalAgentSkillsSha: string | null;\n } & AiFilesPaths,\n): Promise<void> {\n const status = await determineAiFilesStaleness(opts);\n\n if (status === \"not-installed\") {\n logMessage(\n chalkStderr.yellow(\n `Convex AI files are not installed. Run ${chalkStderr.bold(`npx convex ai-files install`)} to get started or ${chalkStderr.bold(`npx convex ai-files disable`)} to hide this message.`,\n ),\n );\n }\n\n if (status === \"stale\") {\n logMessage(\n chalkStderr.yellow(\n `Your Convex AI files are out of date. Run ${chalkStderr.bold(`npx convex ai-files update`)} to get the latest.`,\n ),\n );\n }\n}\n\nexport async function enableAiFiles({\n projectDir,\n convexDir,\n}: AiFilesPaths): Promise<void> {\n await installAiFiles({ projectDir, convexDir });\n const config = await readAiConfig({ projectDir, convexDir });\n if (config === null) return;\n config.enabled = true;\n await writeAiConfig({\n config,\n projectDir,\n convexDir,\n options: { persistEnabledPreference: \"always\" },\n });\n}\n\n/**\n * Remove all Convex AI files from the project.\n * Called by `npx convex ai-files remove`.\n */\nexport async function removeAiFiles({\n projectDir,\n convexDir,\n}: AiFilesPaths): Promise<void> {\n const config = await readAiConfig({ projectDir, convexDir });\n if (config === null) {\n logMessage(\"No Convex AI files found \u2014 nothing to remove.\");\n return;\n }\n\n const removals = [\n await removeAgentsMdSection(projectDir),\n await removeClaudeMdSection(projectDir),\n await removeInstalledSkills({\n projectDir,\n skillNames: config.installedSkillNames,\n }),\n await removeLegacyCursorRules(projectDir),\n await attemptToDeleteAiDir({ projectDir, convexDir }),\n ];\n\n if (removals.some(Boolean)) logMessage(\"Convex AI files removed.\");\n}\n\n/**\n * Called by `npx convex ai-files disable`.\n *\n * Writes a suppression flag into `convex.json` so `npx convex dev` stops\n * showing AI files install/staleness messages. Files are left in place.\n */\nexport async function safelyAttemptToDisableAiFiles(\n projectDir: string,\n): Promise<void> {\n try {\n await writeAiEnabledToProjectConfig({\n projectDir,\n enabled: false,\n });\n logMessage(\n `${chalkStderr.green(`\u2714`)} Convex AI files disabled. Run ${chalkStderr.bold(`npx convex ai-files enable`)} to re-enable.`,\n );\n } catch (error) {\n Sentry.captureException(error);\n logMessage(\n chalkStderr.yellow(\n \"Could not write AI message suppression config. Message may reappear.\",\n ),\n );\n }\n}\n\nasync function attemptToDeleteAiDir({\n projectDir,\n convexDir,\n}: AiFilesPaths): Promise<boolean> {\n const aiDir = aiDirForConvexDir(convexDir);\n const relPath = path.relative(projectDir, aiDir);\n try {\n await fs.rm(aiDir, { recursive: true, force: true });\n logMessage(`${chalkStderr.green(\"\u2714\")} Deleted ${relPath}/`);\n return true;\n } catch (error) {\n Sentry.captureException(error);\n logMessage(\n chalkStderr.yellow(`Could not delete ${relPath}/. Remove it manually.`),\n );\n return false;\n }\n}\n\nasync function hasAiFilesBeenInstalledBefore({\n projectDir,\n convexDir,\n}: AiFilesPaths): Promise<boolean> {\n return (\n (await hasAiFilesConfig({ projectDir, convexDir })) ||\n (await hasExistingAiFilesArtifacts({ projectDir, convexDir }))\n );\n}\n\nexport async function maybeSetupAiFiles({\n ctx,\n convexDir,\n projectDir,\n}: {\n ctx: Context;\n} & AiFilesPaths): Promise<void> {\n if (!isInInteractiveTerminal()) return;\n\n const config = await readAiConfig({ projectDir, convexDir });\n if (config !== null && !config.enabled) return;\n\n if (await hasAiFilesBeenInstalledBefore({ projectDir, convexDir })) {\n await attemptToInstallAiFiles({ projectDir, convexDir });\n return;\n }\n\n const shouldInstall = await promptYesNo(ctx, {\n message: \"Set up Convex AI files? (guidelines, AGENTS.md, agent skills)\",\n default: true,\n });\n\n if (shouldInstall) await attemptToInstallAiFiles({ projectDir, convexDir });\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,aAAwB;AACxB,kBAAiB;AAGjB,gBAA+B;AAC/B,mBAA4B;AAC5B,iBAA2B;AAC3B,qBAA4B;AAC5B,mBAAqD;AACrD,0BAGO;AACP,oBAMO;AACP,mBAAwC;AACxC,sBAIO;AACP,sBAIO;AACP,oBAAqD;AACrD,yBAAuE;AACvE,eAAe,4BAA4B;AAAA,EACzC;AAAA,EACA;AACF,GAAmC;AACjC,SACG,UAAM,4CAAuB,SAAS,KACtC,UAAM,sCAAqB,UAAU,KACrC,UAAM,sCAAqB,UAAU;AAE1C;AASA,eAAsB,eAAe;AAAA,EACnC;AAAA,EACA;AAAA,EACA,wBAAwB;AAAA,EACxB,sBAAsB;AAAA,EACtB,sBAAsB;AAAA,EACtB,oBAAoB;AACtB,GAKkB;AAChB,QAAM,UAAAA,SAAG,UAAM,gCAAkB,SAAS,GAAG,EAAE,WAAW,KAAK,CAAC;AAEhE,QAAM,SAAyB,UAAM,4BAAa;AAAA,IAChD;AAAA,IACA;AAAA,EACF,CAAC,KAAM;AAAA,IACL,SAAS;AAAA,IACT,gBAAgB;AAAA,IAChB,qBAAqB;AAAA,IACrB,cAAc;AAAA,IACd,gBAAgB;AAAA,IAChB,qBAAqB,CAAC;AAAA,EACxB;AAEA,MAAI,sBAAuB,WAAM,2CAAsB,EAAE,WAAW,OAAO,CAAC;AAE5E,QAAM,gBAAgB,YAAAC,QAAK,SAAS,YAAY,SAAS;AAEzD,MAAI;AACF,cAAM,sCAAqB,EAAE,YAAY,QAAQ,cAAc,CAAC;AAElE,MAAI;AACF,cAAM,sCAAqB,EAAE,YAAY,QAAQ,cAAc,CAAC;AAElE,MAAI,kBAAmB,WAAM,6BAAc,EAAE,YAAY,OAAO,CAAC;AAEjE,YAAM,mBAAAC,6BAAwB,UAAU;AACxC,YAAM,6BAAc,EAAE,QAAQ,YAAY,UAAU,CAAC;AAErD,6BAAW,GAAG,yBAAY,MAAM,QAAG,CAAC,6BAA6B;AACnE;AAEA,eAAe,wBACb,MACe;AACf,MAAI;AACF,UAAM,eAAe,IAAI;AAAA,EAC3B,SAAS,OAAO;AACd,WAAO,iBAAiB,KAAK;AAAA,EAC/B;AACF;AASA,eAAe,0BAA0B;AAAA,EACvC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAGmD;AACjD,QAAM,SAAS,UAAM,4BAAa,EAAE,YAAY,UAAU,CAAC;AAE3D,MAAI,WAAW,MAAM;AACnB,UAAM,eAAe,MAAM,4BAA4B;AAAA,MACrD;AAAA,MACA;AAAA,IACF,CAAC;AACD,WAAO,eAAe,kBAAkB;AAAA,EAC1C;AAEA,MAAI,CAAC,OAAO,QAAS,QAAO;AAE5B,MAAI,4BAA4B,QAAQ,4BAA4B;AAClE,WAAO;AAET,QAAM,kBACJ,4BAA4B,QAC5B,OAAO,mBAAmB,QAC1B,OAAO,mBAAmB;AAE5B,QAAM,cACJ,4BAA4B,QAC5B,OAAO,mBAAmB,QAC1B,OAAO,mBAAmB;AAE5B,SAAO,mBAAmB,cAAc,UAAU;AACpD;AAMA,eAAsB,sBACpB,MAIe;AACf,QAAM,SAAS,MAAM,0BAA0B,IAAI;AAEnD,MAAI,WAAW,iBAAiB;AAC9B;AAAA,MACE,yBAAY;AAAA,QACV,0CAA0C,yBAAY,KAAK,6BAA6B,CAAC,sBAAsB,yBAAY,KAAK,6BAA6B,CAAC;AAAA,MAChK;AAAA,IACF;AAAA,EACF;AAEA,MAAI,WAAW,SAAS;AACtB;AAAA,MACE,yBAAY;AAAA,QACV,6CAA6C,yBAAY,KAAK,4BAA4B,CAAC;AAAA,MAC7F;AAAA,IACF;AAAA,EACF;AACF;AAEA,eAAsB,cAAc;AAAA,EAClC;AAAA,EACA;AACF,GAAgC;AAC9B,QAAM,eAAe,EAAE,YAAY,UAAU,CAAC;AAC9C,QAAM,SAAS,UAAM,4BAAa,EAAE,YAAY,UAAU,CAAC;AAC3D,MAAI,WAAW,KAAM;AACrB,SAAO,UAAU;AACjB,YAAM,6BAAc;AAAA,IAClB;AAAA,IACA;AAAA,IACA;AAAA,IACA,SAAS,EAAE,0BAA0B,SAAS;AAAA,EAChD,CAAC;AACH;AAMA,eAAsB,cAAc;AAAA,EAClC;AAAA,EACA;AACF,GAAgC;AAC9B,QAAM,SAAS,UAAM,4BAAa,EAAE,YAAY,UAAU,CAAC;AAC3D,MAAI,WAAW,MAAM;AACnB,+BAAW,oDAA+C;AAC1D;AAAA,EACF;AAEA,QAAM,WAAW;AAAA,IACf,UAAM,uCAAsB,UAAU;AAAA,IACtC,UAAM,uCAAsB,UAAU;AAAA,IACtC,UAAM,qCAAsB;AAAA,MAC1B;AAAA,MACA,YAAY,OAAO;AAAA,IACrB,CAAC;AAAA,IACD,UAAM,mBAAAA,6BAAwB,UAAU;AAAA,IACxC,MAAM,qBAAqB,EAAE,YAAY,UAAU,CAAC;AAAA,EACtD;AAEA,MAAI,SAAS,KAAK,OAAO,EAAG,4BAAW,0BAA0B;AACnE;AAQA,eAAsB,8BACpB,YACe;AACf,MAAI;AACF,cAAM,6CAA8B;AAAA,MAClC;AAAA,MACA,SAAS;AAAA,IACX,CAAC;AACD;AAAA,MACE,GAAG,yBAAY,MAAM,QAAG,CAAC,kCAAkC,yBAAY,KAAK,4BAA4B,CAAC;AAAA,IAC3G;AAAA,EACF,SAAS,OAAO;AACd,WAAO,iBAAiB,KAAK;AAC7B;AAAA,MACE,yBAAY;AAAA,QACV;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;AAEA,eAAe,qBAAqB;AAAA,EAClC;AAAA,EACA;AACF,GAAmC;AACjC,QAAM,YAAQ,gCAAkB,SAAS;AACzC,QAAM,UAAU,YAAAD,QAAK,SAAS,YAAY,KAAK;AAC/C,MAAI;AACF,UAAM,UAAAD,SAAG,GAAG,OAAO,EAAE,WAAW,MAAM,OAAO,KAAK,CAAC;AACnD,+BAAW,GAAG,yBAAY,MAAM,QAAG,CAAC,YAAY,OAAO,GAAG;AAC1D,WAAO;AAAA,EACT,SAAS,OAAO;AACd,WAAO,iBAAiB,KAAK;AAC7B;AAAA,MACE,yBAAY,OAAO,oBAAoB,OAAO,wBAAwB;AAAA,IACxE;AACA,WAAO;AAAA,EACT;AACF;AAEA,eAAe,8BAA8B;AAAA,EAC3C;AAAA,EACA;AACF,GAAmC;AACjC,SACG,UAAM,gCAAiB,EAAE,YAAY,UAAU,CAAC,KAChD,MAAM,4BAA4B,EAAE,YAAY,UAAU,CAAC;AAEhE;AAEA,eAAsB,kBAAkB;AAAA,EACtC;AAAA,EACA;AAAA,EACA;AACF,GAEiC;AAC/B,MAAI,KAAC,sCAAwB,EAAG;AAEhC,QAAM,SAAS,UAAM,4BAAa,EAAE,YAAY,UAAU,CAAC;AAC3D,MAAI,WAAW,QAAQ,CAAC,OAAO,QAAS;AAExC,MAAI,MAAM,8BAA8B,EAAE,YAAY,UAAU,CAAC,GAAG;AAClE,UAAM,wBAAwB,EAAE,YAAY,UAAU,CAAC;AACvD;AAAA,EACF;AAEA,QAAM,gBAAgB,UAAM,4BAAY,KAAK;AAAA,IAC3C,SAAS;AAAA,IACT,SAAS;AAAA,EACX,CAAC;AAED,MAAI,cAAe,OAAM,wBAAwB,EAAE,YAAY,UAAU,CAAC;AAC5E;",
6
+ "names": ["fs", "path", "removeLegacyCursorRules"]
7
+ }
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/cli/lib/aiFiles/paths.ts"],
4
+ "sourcesContent": ["import path from \"path\";\n\nexport type AiFilesPaths = {\n projectDir: string;\n convexDir: string;\n};\n\nconst AI_FILES_PARENT_DIR = \"_generated\";\nconst AI_FILES_DIR = \"ai\";\n\nexport function aiDirForConvexDir(convexDir: string): string {\n return path.join(convexDir, AI_FILES_PARENT_DIR, AI_FILES_DIR);\n}\n\nexport function guidelinesPathForConvexDir(convexDir: string): string {\n return path.join(aiDirForConvexDir(convexDir), \"guidelines.md\");\n}\n\nexport function aiFilesStatePathForConvexDir(convexDir: string): string {\n return path.join(aiDirForConvexDir(convexDir), \"ai-files.state.json\");\n}\n\nexport function agentsMdPath(projectDir?: string): string {\n return path.join(projectDir ?? process.cwd(), \"AGENTS.md\");\n}\n\nexport function claudeMdPath(projectDir?: string): string {\n return path.join(projectDir ?? process.cwd(), \"CLAUDE.md\");\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAAiB;AAOjB,MAAM,sBAAsB;AAC5B,MAAM,eAAe;AAEd,SAAS,kBAAkB,WAA2B;AAC3D,SAAO,YAAAA,QAAK,KAAK,WAAW,qBAAqB,YAAY;AAC/D;AAEO,SAAS,2BAA2B,WAA2B;AACpE,SAAO,YAAAA,QAAK,KAAK,kBAAkB,SAAS,GAAG,eAAe;AAChE;AAEO,SAAS,6BAA6B,WAA2B;AACtE,SAAO,YAAAA,QAAK,KAAK,kBAAkB,SAAS,GAAG,qBAAqB;AACtE;AAEO,SAAS,aAAa,YAA6B;AACxD,SAAO,YAAAA,QAAK,KAAK,cAAc,QAAQ,IAAI,GAAG,WAAW;AAC3D;AAEO,SAAS,aAAa,YAA6B;AACxD,SAAO,YAAAA,QAAK,KAAK,cAAc,QAAQ,IAAI,GAAG,WAAW;AAC3D;",
6
+ "names": ["path"]
7
+ }
@@ -0,0 +1,180 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var skills_exports = {};
30
+ __export(skills_exports, {
31
+ installSkills: () => installSkills,
32
+ removeInstalledSkills: () => removeInstalledSkills
33
+ });
34
+ module.exports = __toCommonJS(skills_exports);
35
+ var import_child_process = __toESM(require("child_process"), 1);
36
+ var import_path = __toESM(require("path"), 1);
37
+ var import_fs = require("fs");
38
+ var import_chalk = require("chalk");
39
+ var import_log = require("../../../bundler/log.js");
40
+ var import_versionApi = require("../versionApi.js");
41
+ var import_utils = require("./utils.js");
42
+ async function readInstalledSkillNames(projectDir) {
43
+ const skillsDir = import_path.default.join(projectDir, ".agents", "skills");
44
+ const entries = await (0, import_utils.iife)(async () => {
45
+ try {
46
+ const dirents = await import_fs.promises.readdir(skillsDir, { withFileTypes: true });
47
+ return dirents.filter((d) => d.isDirectory() || d.isSymbolicLink()).map((d) => d.name);
48
+ } catch {
49
+ return [];
50
+ }
51
+ });
52
+ if (entries.length === 0) return [];
53
+ const names = [];
54
+ for (const entry of entries) {
55
+ const skillMdPath = import_path.default.join(skillsDir, entry, "SKILL.md");
56
+ const content = await (0, import_utils.readFileSafe)(skillMdPath);
57
+ if (content === null) continue;
58
+ const match = content.match(/^---[\s\S]*?^name:\s*(.+?)\s*$/m);
59
+ if (match) {
60
+ names.push(match[1]);
61
+ }
62
+ }
63
+ return names;
64
+ }
65
+ function runSkillsAdd(cwd) {
66
+ return runSkillsCommand(cwd, ["add", "get-convex/agent-skills", "--yes"]);
67
+ }
68
+ function runSkillsRemove({
69
+ cwd,
70
+ skillNames
71
+ }) {
72
+ return runSkillsCommand(cwd, ["remove", ...skillNames, "--yes"]);
73
+ }
74
+ async function shouldRunSkillsCli() {
75
+ const versionData = await (0, import_versionApi.getVersion)();
76
+ if (versionData.kind === "error") return true;
77
+ if (versionData.data.disableSkillsCli) {
78
+ (0, import_log.logMessage)(import_chalk.chalkStderr.yellow(`Agent skills are temporarily disabled.`));
79
+ return false;
80
+ }
81
+ return true;
82
+ }
83
+ async function removeSkillsLockIfEmpty({
84
+ projectDir,
85
+ removedSkillNames
86
+ }) {
87
+ const lockPath = import_path.default.join(projectDir, "skills-lock.json");
88
+ try {
89
+ const content = await import_fs.promises.readFile(lockPath, "utf8");
90
+ const lock = JSON.parse(content);
91
+ if (!lock || typeof lock !== "object" || !lock.skills || typeof lock.skills !== "object") {
92
+ return false;
93
+ }
94
+ const remainingSkills = Object.keys(lock.skills).filter(
95
+ (name) => !removedSkillNames.includes(name)
96
+ );
97
+ if (remainingSkills.length === 0) {
98
+ await import_fs.promises.unlink(lockPath);
99
+ return true;
100
+ }
101
+ return false;
102
+ } catch {
103
+ return false;
104
+ }
105
+ }
106
+ async function installSkills({
107
+ projectDir,
108
+ config
109
+ }) {
110
+ if (!await shouldRunSkillsCli()) return;
111
+ (0, import_log.logMessage)("Installing Convex agent skills...");
112
+ const skillsOk = await runSkillsAdd(projectDir);
113
+ if (!skillsOk) {
114
+ (0, import_log.logMessage)(
115
+ import_chalk.chalkStderr.yellow(
116
+ "Could not install agent skills. You can retry manually with: npx skills add get-convex/agent-skills"
117
+ )
118
+ );
119
+ return;
120
+ }
121
+ const sha = await (0, import_versionApi.fetchAgentSkillsSha)();
122
+ if (sha) config.agentSkillsSha = sha;
123
+ const names = await readInstalledSkillNames(projectDir);
124
+ if (names.length > 0) config.installedSkillNames = names;
125
+ }
126
+ async function removeInstalledSkills({
127
+ projectDir,
128
+ skillNames
129
+ }) {
130
+ if (skillNames.length === 0 || !await shouldRunSkillsCli()) return false;
131
+ (0, import_log.logMessage)(`Removing Convex agent skills: ${skillNames.join(", ")}`);
132
+ const skillsOk = await runSkillsRemove({ cwd: projectDir, skillNames });
133
+ if (!skillsOk) {
134
+ (0, import_log.logMessage)(
135
+ import_chalk.chalkStderr.yellow(
136
+ "Could not remove agent skills automatically. Remove them manually with: npx skills remove"
137
+ )
138
+ );
139
+ return false;
140
+ }
141
+ const lockRemoved = await removeSkillsLockIfEmpty({
142
+ projectDir,
143
+ removedSkillNames: skillNames
144
+ });
145
+ if (lockRemoved)
146
+ (0, import_log.logMessage)(`${import_chalk.chalkStderr.green("\u2714")} Deleted skills-lock.json.`);
147
+ return true;
148
+ }
149
+ function runSkillsCommand(cwd, args) {
150
+ return new Promise((resolve) => {
151
+ const proc = import_child_process.default.spawn(
152
+ "npx",
153
+ ["--yes", "skills@latest", ...args],
154
+ {
155
+ cwd,
156
+ stdio: "pipe",
157
+ // .cmd files on Windows require shell execution.
158
+ shell: process.platform === "win32"
159
+ }
160
+ );
161
+ let capturedOutput = "";
162
+ proc.stdout?.on("data", (chunk) => {
163
+ capturedOutput += chunk.toString();
164
+ });
165
+ proc.stderr?.on("data", (chunk) => {
166
+ capturedOutput += chunk.toString();
167
+ });
168
+ proc.on("close", (code) => {
169
+ if (code !== 0 && capturedOutput.trim().length > 0) {
170
+ const lines = capturedOutput.trim().split(/\r?\n/);
171
+ const tail = lines.slice(-10).join("\n");
172
+ (0, import_log.logMessage)(import_chalk.chalkStderr.gray(`skills output (tail):
173
+ ${tail}`));
174
+ }
175
+ resolve(code === 0);
176
+ });
177
+ proc.on("error", () => resolve(false));
178
+ });
179
+ }
180
+ //# sourceMappingURL=skills.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/cli/lib/aiFiles/skills.ts"],
4
+ "sourcesContent": ["import child_process from \"child_process\";\nimport path from \"path\";\n// eslint-disable-next-line no-restricted-imports\nimport { promises as fs } from \"fs\";\nimport { chalkStderr } from \"chalk\";\nimport { logMessage } from \"../../../bundler/log.js\";\nimport { getVersion, fetchAgentSkillsSha } from \"../versionApi.js\";\nimport { type AiFilesConfig } from \"./config.js\";\nimport { iife, readFileSafe } from \"./utils.js\";\n\n/**\n * Read the frontmatter `name:` values from skills installed by the skills CLI.\n */\nasync function readInstalledSkillNames(projectDir: string): Promise<string[]> {\n const skillsDir = path.join(projectDir, \".agents\", \"skills\");\n const entries = await iife(async () => {\n try {\n const dirents = await fs.readdir(skillsDir, { withFileTypes: true });\n return dirents\n .filter((d) => d.isDirectory() || d.isSymbolicLink())\n .map((d) => d.name);\n } catch {\n return [] as string[];\n }\n });\n if (entries.length === 0) return [];\n\n const names: string[] = [];\n for (const entry of entries) {\n const skillMdPath = path.join(skillsDir, entry, \"SKILL.md\");\n const content = await readFileSafe(skillMdPath);\n if (content === null) continue;\n const match = content.match(/^---[\\s\\S]*?^name:\\s*(.+?)\\s*$/m);\n if (match) {\n names.push(match[1]);\n }\n }\n return names;\n}\n\n/**\n * Runs `npx skills add get-convex/agent-skills --yes` in the given directory.\n * Returns true on success, false if the process fails or cannot be started.\n */\nfunction runSkillsAdd(cwd: string): Promise<boolean> {\n return runSkillsCommand(cwd, [\"add\", \"get-convex/agent-skills\", \"--yes\"]);\n}\n\n/**\n * Runs `npx skills remove <name...> --yes` to surgically remove only the\n * Convex-managed skills, leaving any skills from other sources intact.\n */\nfunction runSkillsRemove({\n cwd,\n skillNames,\n}: {\n cwd: string;\n skillNames: string[];\n}): Promise<boolean> {\n return runSkillsCommand(cwd, [\"remove\", ...skillNames, \"--yes\"]);\n}\n\n/**\n * This function exists so we have a way to disable skills installs without pushing a new\n * version of the convex CLI\n */\nasync function shouldRunSkillsCli(): Promise<boolean> {\n const versionData = await getVersion();\n\n if (versionData.kind === \"error\") return true;\n\n if (versionData.data.disableSkillsCli) {\n logMessage(chalkStderr.yellow(`Agent skills are temporarily disabled.`));\n return false;\n }\n\n return true;\n}\n\n/**\n * Remove the skills-lock.json file if it only contains skills that we\n * are removing. The `npx skills remove` command leaves the lockfile behind\n * even when it's logically empty.\n */\nasync function removeSkillsLockIfEmpty({\n projectDir,\n removedSkillNames,\n}: {\n projectDir: string;\n removedSkillNames: string[];\n}): Promise<boolean> {\n const lockPath = path.join(projectDir, \"skills-lock.json\");\n try {\n const content = await fs.readFile(lockPath, \"utf8\");\n const lock = JSON.parse(content);\n\n if (\n !lock ||\n typeof lock !== \"object\" ||\n !lock.skills ||\n typeof lock.skills !== \"object\"\n ) {\n return false;\n }\n\n const remainingSkills = Object.keys(lock.skills).filter(\n (name) => !removedSkillNames.includes(name),\n );\n\n if (remainingSkills.length === 0) {\n await fs.unlink(lockPath);\n return true;\n }\n return false;\n } catch {\n return false;\n }\n}\n\n/**\n * Install Convex agent skills and record the SHA and names into the config.\n * Handles the kill-switch check and all logging internally.\n */\nexport async function installSkills({\n projectDir,\n config,\n}: {\n projectDir: string;\n config: AiFilesConfig;\n}): Promise<void> {\n if (!(await shouldRunSkillsCli())) return;\n\n logMessage(\"Installing Convex agent skills...\");\n const skillsOk = await runSkillsAdd(projectDir);\n if (!skillsOk) {\n logMessage(\n chalkStderr.yellow(\n \"Could not install agent skills. You can retry manually with: npx skills add get-convex/agent-skills\",\n ),\n );\n return;\n }\n\n const sha = await fetchAgentSkillsSha();\n if (sha) config.agentSkillsSha = sha;\n\n const names = await readInstalledSkillNames(projectDir);\n if (names.length > 0) config.installedSkillNames = names;\n}\n\n/**\n * Remove Convex-managed agent skills and clean up the lock file if empty.\n * Returns true if any removal occurred.\n */\nexport async function removeInstalledSkills({\n projectDir,\n skillNames,\n}: {\n projectDir: string;\n skillNames: string[];\n}): Promise<boolean> {\n if (skillNames.length === 0 || !(await shouldRunSkillsCli())) return false;\n\n logMessage(`Removing Convex agent skills: ${skillNames.join(\", \")}`);\n const skillsOk = await runSkillsRemove({ cwd: projectDir, skillNames });\n if (!skillsOk) {\n logMessage(\n chalkStderr.yellow(\n \"Could not remove agent skills automatically. Remove them manually with: npx skills remove\",\n ),\n );\n return false;\n }\n\n const lockRemoved = await removeSkillsLockIfEmpty({\n projectDir,\n removedSkillNames: skillNames,\n });\n if (lockRemoved)\n logMessage(`${chalkStderr.green(\"\u2714\")} Deleted skills-lock.json.`);\n return true;\n}\n\nfunction runSkillsCommand(cwd: string, args: string[]): Promise<boolean> {\n return new Promise((resolve) => {\n const proc = child_process.spawn(\n \"npx\",\n [\"--yes\", \"skills@latest\", ...args],\n {\n cwd,\n stdio: \"pipe\",\n // .cmd files on Windows require shell execution.\n shell: process.platform === \"win32\",\n },\n );\n let capturedOutput = \"\";\n proc.stdout?.on(\"data\", (chunk) => {\n capturedOutput += chunk.toString();\n });\n proc.stderr?.on(\"data\", (chunk) => {\n capturedOutput += chunk.toString();\n });\n proc.on(\"close\", (code) => {\n if (code !== 0 && capturedOutput.trim().length > 0) {\n const lines = capturedOutput.trim().split(/\\r?\\n/);\n const tail = lines.slice(-10).join(\"\\n\");\n logMessage(chalkStderr.gray(`skills output (tail):\\n${tail}`));\n }\n resolve(code === 0);\n });\n proc.on(\"error\", () => resolve(false));\n });\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,2BAA0B;AAC1B,kBAAiB;AAEjB,gBAA+B;AAC/B,mBAA4B;AAC5B,iBAA2B;AAC3B,wBAAgD;AAEhD,mBAAmC;AAKnC,eAAe,wBAAwB,YAAuC;AAC5E,QAAM,YAAY,YAAAA,QAAK,KAAK,YAAY,WAAW,QAAQ;AAC3D,QAAM,UAAU,UAAM,mBAAK,YAAY;AACrC,QAAI;AACF,YAAM,UAAU,MAAM,UAAAC,SAAG,QAAQ,WAAW,EAAE,eAAe,KAAK,CAAC;AACnE,aAAO,QACJ,OAAO,CAAC,MAAM,EAAE,YAAY,KAAK,EAAE,eAAe,CAAC,EACnD,IAAI,CAAC,MAAM,EAAE,IAAI;AAAA,IACtB,QAAQ;AACN,aAAO,CAAC;AAAA,IACV;AAAA,EACF,CAAC;AACD,MAAI,QAAQ,WAAW,EAAG,QAAO,CAAC;AAElC,QAAM,QAAkB,CAAC;AACzB,aAAW,SAAS,SAAS;AAC3B,UAAM,cAAc,YAAAD,QAAK,KAAK,WAAW,OAAO,UAAU;AAC1D,UAAM,UAAU,UAAM,2BAAa,WAAW;AAC9C,QAAI,YAAY,KAAM;AACtB,UAAM,QAAQ,QAAQ,MAAM,iCAAiC;AAC7D,QAAI,OAAO;AACT,YAAM,KAAK,MAAM,CAAC,CAAC;AAAA,IACrB;AAAA,EACF;AACA,SAAO;AACT;AAMA,SAAS,aAAa,KAA+B;AACnD,SAAO,iBAAiB,KAAK,CAAC,OAAO,2BAA2B,OAAO,CAAC;AAC1E;AAMA,SAAS,gBAAgB;AAAA,EACvB;AAAA,EACA;AACF,GAGqB;AACnB,SAAO,iBAAiB,KAAK,CAAC,UAAU,GAAG,YAAY,OAAO,CAAC;AACjE;AAMA,eAAe,qBAAuC;AACpD,QAAM,cAAc,UAAM,8BAAW;AAErC,MAAI,YAAY,SAAS,QAAS,QAAO;AAEzC,MAAI,YAAY,KAAK,kBAAkB;AACrC,+BAAW,yBAAY,OAAO,wCAAwC,CAAC;AACvE,WAAO;AAAA,EACT;AAEA,SAAO;AACT;AAOA,eAAe,wBAAwB;AAAA,EACrC;AAAA,EACA;AACF,GAGqB;AACnB,QAAM,WAAW,YAAAA,QAAK,KAAK,YAAY,kBAAkB;AACzD,MAAI;AACF,UAAM,UAAU,MAAM,UAAAC,SAAG,SAAS,UAAU,MAAM;AAClD,UAAM,OAAO,KAAK,MAAM,OAAO;AAE/B,QACE,CAAC,QACD,OAAO,SAAS,YAChB,CAAC,KAAK,UACN,OAAO,KAAK,WAAW,UACvB;AACA,aAAO;AAAA,IACT;AAEA,UAAM,kBAAkB,OAAO,KAAK,KAAK,MAAM,EAAE;AAAA,MAC/C,CAAC,SAAS,CAAC,kBAAkB,SAAS,IAAI;AAAA,IAC5C;AAEA,QAAI,gBAAgB,WAAW,GAAG;AAChC,YAAM,UAAAA,SAAG,OAAO,QAAQ;AACxB,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAMA,eAAsB,cAAc;AAAA,EAClC;AAAA,EACA;AACF,GAGkB;AAChB,MAAI,CAAE,MAAM,mBAAmB,EAAI;AAEnC,6BAAW,mCAAmC;AAC9C,QAAM,WAAW,MAAM,aAAa,UAAU;AAC9C,MAAI,CAAC,UAAU;AACb;AAAA,MACE,yBAAY;AAAA,QACV;AAAA,MACF;AAAA,IACF;AACA;AAAA,EACF;AAEA,QAAM,MAAM,UAAM,uCAAoB;AACtC,MAAI,IAAK,QAAO,iBAAiB;AAEjC,QAAM,QAAQ,MAAM,wBAAwB,UAAU;AACtD,MAAI,MAAM,SAAS,EAAG,QAAO,sBAAsB;AACrD;AAMA,eAAsB,sBAAsB;AAAA,EAC1C;AAAA,EACA;AACF,GAGqB;AACnB,MAAI,WAAW,WAAW,KAAK,CAAE,MAAM,mBAAmB,EAAI,QAAO;AAErE,6BAAW,iCAAiC,WAAW,KAAK,IAAI,CAAC,EAAE;AACnE,QAAM,WAAW,MAAM,gBAAgB,EAAE,KAAK,YAAY,WAAW,CAAC;AACtE,MAAI,CAAC,UAAU;AACb;AAAA,MACE,yBAAY;AAAA,QACV;AAAA,MACF;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAEA,QAAM,cAAc,MAAM,wBAAwB;AAAA,IAChD;AAAA,IACA,mBAAmB;AAAA,EACrB,CAAC;AACD,MAAI;AACF,+BAAW,GAAG,yBAAY,MAAM,QAAG,CAAC,4BAA4B;AAClE,SAAO;AACT;AAEA,SAAS,iBAAiB,KAAa,MAAkC;AACvE,SAAO,IAAI,QAAQ,CAAC,YAAY;AAC9B,UAAM,OAAO,qBAAAC,QAAc;AAAA,MACzB;AAAA,MACA,CAAC,SAAS,iBAAiB,GAAG,IAAI;AAAA,MAClC;AAAA,QACE;AAAA,QACA,OAAO;AAAA;AAAA,QAEP,OAAO,QAAQ,aAAa;AAAA,MAC9B;AAAA,IACF;AACA,QAAI,iBAAiB;AACrB,SAAK,QAAQ,GAAG,QAAQ,CAAC,UAAU;AACjC,wBAAkB,MAAM,SAAS;AAAA,IACnC,CAAC;AACD,SAAK,QAAQ,GAAG,QAAQ,CAAC,UAAU;AACjC,wBAAkB,MAAM,SAAS;AAAA,IACnC,CAAC;AACD,SAAK,GAAG,SAAS,CAAC,SAAS;AACzB,UAAI,SAAS,KAAK,eAAe,KAAK,EAAE,SAAS,GAAG;AAClD,cAAM,QAAQ,eAAe,KAAK,EAAE,MAAM,OAAO;AACjD,cAAM,OAAO,MAAM,MAAM,GAAG,EAAE,KAAK,IAAI;AACvC,mCAAW,yBAAY,KAAK;AAAA,EAA0B,IAAI,EAAE,CAAC;AAAA,MAC/D;AACA,cAAQ,SAAS,CAAC;AAAA,IACpB,CAAC;AACD,SAAK,GAAG,SAAS,MAAM,QAAQ,KAAK,CAAC;AAAA,EACvC,CAAC;AACH;",
6
+ "names": ["path", "fs", "child_process"]
7
+ }