eslint-plugin-copilot 1.0.5

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 (424) hide show
  1. package/CHANGELOG.md +5316 -0
  2. package/LICENSE +21 -0
  3. package/README.md +192 -0
  4. package/dist/_internal/copilot-config-references.d.ts +34 -0
  5. package/dist/_internal/copilot-config-references.d.ts.map +1 -0
  6. package/dist/_internal/copilot-config-references.js +55 -0
  7. package/dist/_internal/copilot-config-references.js.map +1 -0
  8. package/dist/_internal/copilot-customization-names.d.ts +21 -0
  9. package/dist/_internal/copilot-customization-names.d.ts.map +1 -0
  10. package/dist/_internal/copilot-customization-names.js +56 -0
  11. package/dist/_internal/copilot-customization-names.js.map +1 -0
  12. package/dist/_internal/copilot-file-kind.d.ts +19 -0
  13. package/dist/_internal/copilot-file-kind.d.ts.map +1 -0
  14. package/dist/_internal/copilot-file-kind.js +111 -0
  15. package/dist/_internal/copilot-file-kind.js.map +1 -0
  16. package/dist/_internal/create-copilot-rule.d.ts +39 -0
  17. package/dist/_internal/create-copilot-rule.d.ts.map +1 -0
  18. package/dist/_internal/create-copilot-rule.js +56 -0
  19. package/dist/_internal/create-copilot-rule.js.map +1 -0
  20. package/dist/_internal/customization-body.d.ts +6 -0
  21. package/dist/_internal/customization-body.d.ts.map +1 -0
  22. package/dist/_internal/customization-body.js +15 -0
  23. package/dist/_internal/customization-body.js.map +1 -0
  24. package/dist/_internal/duplicate-names.d.ts +12 -0
  25. package/dist/_internal/duplicate-names.d.ts.map +1 -0
  26. package/dist/_internal/duplicate-names.js +24 -0
  27. package/dist/_internal/duplicate-names.js.map +1 -0
  28. package/dist/_internal/file-system.d.ts +21 -0
  29. package/dist/_internal/file-system.d.ts.map +1 -0
  30. package/dist/_internal/file-system.js +86 -0
  31. package/dist/_internal/file-system.js.map +1 -0
  32. package/dist/_internal/frontmatter.d.ts +37 -0
  33. package/dist/_internal/frontmatter.d.ts.map +1 -0
  34. package/dist/_internal/frontmatter.js +398 -0
  35. package/dist/_internal/frontmatter.js.map +1 -0
  36. package/dist/_internal/markdown-links.d.ts +21 -0
  37. package/dist/_internal/markdown-links.d.ts.map +1 -0
  38. package/dist/_internal/markdown-links.js +81 -0
  39. package/dist/_internal/markdown-links.js.map +1 -0
  40. package/dist/_internal/markdown-rule.d.ts +13 -0
  41. package/dist/_internal/markdown-rule.d.ts.map +1 -0
  42. package/dist/_internal/markdown-rule.js +19 -0
  43. package/dist/_internal/markdown-rule.js.map +1 -0
  44. package/dist/_internal/repository-hooks-json.d.ts +55 -0
  45. package/dist/_internal/repository-hooks-json.d.ts.map +1 -0
  46. package/dist/_internal/repository-hooks-json.js +80 -0
  47. package/dist/_internal/repository-hooks-json.js.map +1 -0
  48. package/dist/_internal/rule-catalog.d.ts +20 -0
  49. package/dist/_internal/rule-catalog.d.ts.map +1 -0
  50. package/dist/_internal/rule-catalog.js +97 -0
  51. package/dist/_internal/rule-catalog.js.map +1 -0
  52. package/dist/_internal/rule-docs-url.d.ts +9 -0
  53. package/dist/_internal/rule-docs-url.d.ts.map +1 -0
  54. package/dist/_internal/rule-docs-url.js +9 -0
  55. package/dist/_internal/rule-docs-url.js.map +1 -0
  56. package/dist/_internal/rules-registry.d.ts +83 -0
  57. package/dist/_internal/rules-registry.d.ts.map +1 -0
  58. package/dist/_internal/rules-registry.js +145 -0
  59. package/dist/_internal/rules-registry.js.map +1 -0
  60. package/dist/_internal/skill-files.d.ts +8 -0
  61. package/dist/_internal/skill-files.d.ts.map +1 -0
  62. package/dist/_internal/skill-files.js +18 -0
  63. package/dist/_internal/skill-files.js.map +1 -0
  64. package/dist/plugin.cjs +5312 -0
  65. package/dist/plugin.cjs.map +7 -0
  66. package/dist/plugin.d.cts +34 -0
  67. package/dist/plugin.d.ts +34 -0
  68. package/dist/plugin.d.ts.map +1 -0
  69. package/dist/plugin.js +142 -0
  70. package/dist/plugin.js.map +1 -0
  71. package/dist/rules/no-blank-customization-body.d.ts +4 -0
  72. package/dist/rules/no-blank-customization-body.d.ts.map +1 -0
  73. package/dist/rules/no-blank-customization-body.js +49 -0
  74. package/dist/rules/no-blank-customization-body.js.map +1 -0
  75. package/dist/rules/no-blank-repository-instructions.d.ts +4 -0
  76. package/dist/rules/no-blank-repository-instructions.d.ts.map +1 -0
  77. package/dist/rules/no-blank-repository-instructions.js +49 -0
  78. package/dist/rules/no-blank-repository-instructions.js.map +1 -0
  79. package/dist/rules/no-blank-skill-body.d.ts +4 -0
  80. package/dist/rules/no-blank-skill-body.d.ts.map +1 -0
  81. package/dist/rules/no-blank-skill-body.js +48 -0
  82. package/dist/rules/no-blank-skill-body.js.map +1 -0
  83. package/dist/rules/no-deprecated-agent-infer.d.ts +4 -0
  84. package/dist/rules/no-deprecated-agent-infer.d.ts.map +1 -0
  85. package/dist/rules/no-deprecated-agent-infer.js +48 -0
  86. package/dist/rules/no-deprecated-agent-infer.js.map +1 -0
  87. package/dist/rules/no-duplicate-agent-names.d.ts +4 -0
  88. package/dist/rules/no-duplicate-agent-names.d.ts.map +1 -0
  89. package/dist/rules/no-duplicate-agent-names.js +72 -0
  90. package/dist/rules/no-duplicate-agent-names.js.map +1 -0
  91. package/dist/rules/no-duplicate-prompt-names.d.ts +4 -0
  92. package/dist/rules/no-duplicate-prompt-names.d.ts.map +1 -0
  93. package/dist/rules/no-duplicate-prompt-names.js +72 -0
  94. package/dist/rules/no-duplicate-prompt-names.js.map +1 -0
  95. package/dist/rules/no-duplicate-skill-names.d.ts +4 -0
  96. package/dist/rules/no-duplicate-skill-names.d.ts.map +1 -0
  97. package/dist/rules/no-duplicate-skill-names.js +74 -0
  98. package/dist/rules/no-duplicate-skill-names.js.map +1 -0
  99. package/dist/rules/no-duplicate-slash-command-names.d.ts +4 -0
  100. package/dist/rules/no-duplicate-slash-command-names.d.ts.map +1 -0
  101. package/dist/rules/no-duplicate-slash-command-names.js +82 -0
  102. package/dist/rules/no-duplicate-slash-command-names.js.map +1 -0
  103. package/dist/rules/no-empty-repository-hook-arrays.d.ts +4 -0
  104. package/dist/rules/no-empty-repository-hook-arrays.d.ts.map +1 -0
  105. package/dist/rules/no-empty-repository-hook-arrays.js +49 -0
  106. package/dist/rules/no-empty-repository-hook-arrays.js.map +1 -0
  107. package/dist/rules/no-legacy-chatmode-files.d.ts +4 -0
  108. package/dist/rules/no-legacy-chatmode-files.d.ts.map +1 -0
  109. package/dist/rules/no-legacy-chatmode-files.js +42 -0
  110. package/dist/rules/no-legacy-chatmode-files.js.map +1 -0
  111. package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts +4 -0
  112. package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts.map +1 -0
  113. package/dist/rules/prefer-custom-instructions-under-code-review-limit.js +52 -0
  114. package/dist/rules/prefer-custom-instructions-under-code-review-limit.js.map +1 -0
  115. package/dist/rules/prefer-fast-repository-hooks.d.ts +4 -0
  116. package/dist/rules/prefer-fast-repository-hooks.d.ts.map +1 -0
  117. package/dist/rules/prefer-fast-repository-hooks.js +58 -0
  118. package/dist/rules/prefer-fast-repository-hooks.js.map +1 -0
  119. package/dist/rules/prefer-qualified-tools.d.ts +4 -0
  120. package/dist/rules/prefer-qualified-tools.d.ts.map +1 -0
  121. package/dist/rules/prefer-qualified-tools.js +56 -0
  122. package/dist/rules/prefer-qualified-tools.js.map +1 -0
  123. package/dist/rules/require-agent-tool-for-subagents.d.ts +4 -0
  124. package/dist/rules/require-agent-tool-for-subagents.d.ts.map +1 -0
  125. package/dist/rules/require-agent-tool-for-subagents.js +64 -0
  126. package/dist/rules/require-agent-tool-for-subagents.js.map +1 -0
  127. package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts +4 -0
  128. package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts.map +1 -0
  129. package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js +50 -0
  130. package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js.map +1 -0
  131. package/dist/rules/require-chatmode-file-metadata.d.ts +4 -0
  132. package/dist/rules/require-chatmode-file-metadata.d.ts.map +1 -0
  133. package/dist/rules/require-chatmode-file-metadata.js +59 -0
  134. package/dist/rules/require-chatmode-file-metadata.js.map +1 -0
  135. package/dist/rules/require-existing-agent-hook-cwd.d.ts +4 -0
  136. package/dist/rules/require-existing-agent-hook-cwd.d.ts.map +1 -0
  137. package/dist/rules/require-existing-agent-hook-cwd.js +64 -0
  138. package/dist/rules/require-existing-agent-hook-cwd.js.map +1 -0
  139. package/dist/rules/require-existing-agent-mcp-servers.d.ts +4 -0
  140. package/dist/rules/require-existing-agent-mcp-servers.d.ts.map +1 -0
  141. package/dist/rules/require-existing-agent-mcp-servers.js +58 -0
  142. package/dist/rules/require-existing-agent-mcp-servers.js.map +1 -0
  143. package/dist/rules/require-existing-relative-agent-links.d.ts +4 -0
  144. package/dist/rules/require-existing-relative-agent-links.d.ts.map +1 -0
  145. package/dist/rules/require-existing-relative-agent-links.js +61 -0
  146. package/dist/rules/require-existing-relative-agent-links.js.map +1 -0
  147. package/dist/rules/require-existing-relative-instructions-links.d.ts +4 -0
  148. package/dist/rules/require-existing-relative-instructions-links.d.ts.map +1 -0
  149. package/dist/rules/require-existing-relative-instructions-links.js +61 -0
  150. package/dist/rules/require-existing-relative-instructions-links.js.map +1 -0
  151. package/dist/rules/require-existing-relative-prompt-links.d.ts +4 -0
  152. package/dist/rules/require-existing-relative-prompt-links.d.ts.map +1 -0
  153. package/dist/rules/require-existing-relative-prompt-links.js +61 -0
  154. package/dist/rules/require-existing-relative-prompt-links.js.map +1 -0
  155. package/dist/rules/require-existing-relative-skill-links.d.ts +4 -0
  156. package/dist/rules/require-existing-relative-skill-links.d.ts.map +1 -0
  157. package/dist/rules/require-existing-relative-skill-links.js +61 -0
  158. package/dist/rules/require-existing-relative-skill-links.js.map +1 -0
  159. package/dist/rules/require-existing-repository-hook-cwd.d.ts +4 -0
  160. package/dist/rules/require-existing-repository-hook-cwd.d.ts.map +1 -0
  161. package/dist/rules/require-existing-repository-hook-cwd.js +65 -0
  162. package/dist/rules/require-existing-repository-hook-cwd.js.map +1 -0
  163. package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts +4 -0
  164. package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts.map +1 -0
  165. package/dist/rules/require-github-copilot-target-for-mcp-servers.js +63 -0
  166. package/dist/rules/require-github-copilot-target-for-mcp-servers.js.map +1 -0
  167. package/dist/rules/require-instructions-apply-to.d.ts +4 -0
  168. package/dist/rules/require-instructions-apply-to.d.ts.map +1 -0
  169. package/dist/rules/require-instructions-apply-to.js +60 -0
  170. package/dist/rules/require-instructions-apply-to.js.map +1 -0
  171. package/dist/rules/require-json-agent-mcp-servers.d.ts +4 -0
  172. package/dist/rules/require-json-agent-mcp-servers.d.ts.map +1 -0
  173. package/dist/rules/require-json-agent-mcp-servers.js +58 -0
  174. package/dist/rules/require-json-agent-mcp-servers.js.map +1 -0
  175. package/dist/rules/require-prompt-file-metadata.d.ts +4 -0
  176. package/dist/rules/require-prompt-file-metadata.d.ts.map +1 -0
  177. package/dist/rules/require-prompt-file-metadata.js +104 -0
  178. package/dist/rules/require-prompt-file-metadata.js.map +1 -0
  179. package/dist/rules/require-qualified-agent-handoff-models.d.ts +4 -0
  180. package/dist/rules/require-qualified-agent-handoff-models.d.ts.map +1 -0
  181. package/dist/rules/require-qualified-agent-handoff-models.js +78 -0
  182. package/dist/rules/require-qualified-agent-handoff-models.js.map +1 -0
  183. package/dist/rules/require-relative-agent-hook-cwd.d.ts +4 -0
  184. package/dist/rules/require-relative-agent-hook-cwd.d.ts.map +1 -0
  185. package/dist/rules/require-relative-agent-hook-cwd.js +70 -0
  186. package/dist/rules/require-relative-agent-hook-cwd.js.map +1 -0
  187. package/dist/rules/require-relative-agent-links.d.ts +4 -0
  188. package/dist/rules/require-relative-agent-links.d.ts.map +1 -0
  189. package/dist/rules/require-relative-agent-links.js +58 -0
  190. package/dist/rules/require-relative-agent-links.js.map +1 -0
  191. package/dist/rules/require-relative-instructions-links.d.ts +4 -0
  192. package/dist/rules/require-relative-instructions-links.d.ts.map +1 -0
  193. package/dist/rules/require-relative-instructions-links.js +58 -0
  194. package/dist/rules/require-relative-instructions-links.js.map +1 -0
  195. package/dist/rules/require-relative-prompt-links.d.ts +4 -0
  196. package/dist/rules/require-relative-prompt-links.d.ts.map +1 -0
  197. package/dist/rules/require-relative-prompt-links.js +82 -0
  198. package/dist/rules/require-relative-prompt-links.js.map +1 -0
  199. package/dist/rules/require-relative-repository-hook-cwd.d.ts +4 -0
  200. package/dist/rules/require-relative-repository-hook-cwd.d.ts.map +1 -0
  201. package/dist/rules/require-relative-repository-hook-cwd.js +63 -0
  202. package/dist/rules/require-relative-repository-hook-cwd.js.map +1 -0
  203. package/dist/rules/require-relative-skill-links.d.ts +4 -0
  204. package/dist/rules/require-relative-skill-links.d.ts.map +1 -0
  205. package/dist/rules/require-relative-skill-links.js +58 -0
  206. package/dist/rules/require-relative-skill-links.js.map +1 -0
  207. package/dist/rules/require-repository-hook-arrays.d.ts +4 -0
  208. package/dist/rules/require-repository-hook-arrays.d.ts.map +1 -0
  209. package/dist/rules/require-repository-hook-arrays.js +54 -0
  210. package/dist/rules/require-repository-hook-arrays.js.map +1 -0
  211. package/dist/rules/require-repository-hook-command-shell.d.ts +4 -0
  212. package/dist/rules/require-repository-hook-command-shell.d.ts.map +1 -0
  213. package/dist/rules/require-repository-hook-command-shell.js +57 -0
  214. package/dist/rules/require-repository-hook-command-shell.js.map +1 -0
  215. package/dist/rules/require-repository-hooks-object.d.ts +4 -0
  216. package/dist/rules/require-repository-hooks-object.d.ts.map +1 -0
  217. package/dist/rules/require-repository-hooks-object.js +50 -0
  218. package/dist/rules/require-repository-hooks-object.js.map +1 -0
  219. package/dist/rules/require-repository-instructions-file.d.ts +4 -0
  220. package/dist/rules/require-repository-instructions-file.d.ts.map +1 -0
  221. package/dist/rules/require-repository-instructions-file.js +50 -0
  222. package/dist/rules/require-repository-instructions-file.js.map +1 -0
  223. package/dist/rules/require-skill-file-location.d.ts +4 -0
  224. package/dist/rules/require-skill-file-location.d.ts.map +1 -0
  225. package/dist/rules/require-skill-file-location.js +46 -0
  226. package/dist/rules/require-skill-file-location.js.map +1 -0
  227. package/dist/rules/require-skill-file-metadata.d.ts +4 -0
  228. package/dist/rules/require-skill-file-metadata.d.ts.map +1 -0
  229. package/dist/rules/require-skill-file-metadata.js +60 -0
  230. package/dist/rules/require-skill-file-metadata.js.map +1 -0
  231. package/dist/rules/require-skill-md-filename.d.ts +4 -0
  232. package/dist/rules/require-skill-md-filename.d.ts.map +1 -0
  233. package/dist/rules/require-skill-md-filename.js +55 -0
  234. package/dist/rules/require-skill-md-filename.js.map +1 -0
  235. package/dist/rules/require-skill-name-match-directory.d.ts +4 -0
  236. package/dist/rules/require-skill-name-match-directory.d.ts.map +1 -0
  237. package/dist/rules/require-skill-name-match-directory.js +59 -0
  238. package/dist/rules/require-skill-name-match-directory.js.map +1 -0
  239. package/dist/rules/require-string-repository-hook-env-values.d.ts +4 -0
  240. package/dist/rules/require-string-repository-hook-env-values.d.ts.map +1 -0
  241. package/dist/rules/require-string-repository-hook-env-values.js +59 -0
  242. package/dist/rules/require-string-repository-hook-env-values.js.map +1 -0
  243. package/dist/rules/require-valid-agent-argument-hint.d.ts +4 -0
  244. package/dist/rules/require-valid-agent-argument-hint.d.ts.map +1 -0
  245. package/dist/rules/require-valid-agent-argument-hint.js +51 -0
  246. package/dist/rules/require-valid-agent-argument-hint.js.map +1 -0
  247. package/dist/rules/require-valid-agent-handoff-send.d.ts +4 -0
  248. package/dist/rules/require-valid-agent-handoff-send.d.ts.map +1 -0
  249. package/dist/rules/require-valid-agent-handoff-send.js +67 -0
  250. package/dist/rules/require-valid-agent-handoff-send.js.map +1 -0
  251. package/dist/rules/require-valid-agent-handoffs.d.ts +4 -0
  252. package/dist/rules/require-valid-agent-handoffs.d.ts.map +1 -0
  253. package/dist/rules/require-valid-agent-handoffs.js +78 -0
  254. package/dist/rules/require-valid-agent-handoffs.js.map +1 -0
  255. package/dist/rules/require-valid-agent-hook-events.d.ts +4 -0
  256. package/dist/rules/require-valid-agent-hook-events.d.ts.map +1 -0
  257. package/dist/rules/require-valid-agent-hook-events.js +68 -0
  258. package/dist/rules/require-valid-agent-hook-events.js.map +1 -0
  259. package/dist/rules/require-valid-agent-hook-timeouts.d.ts +4 -0
  260. package/dist/rules/require-valid-agent-hook-timeouts.d.ts.map +1 -0
  261. package/dist/rules/require-valid-agent-hook-timeouts.js +83 -0
  262. package/dist/rules/require-valid-agent-hook-timeouts.js.map +1 -0
  263. package/dist/rules/require-valid-agent-hooks.d.ts +4 -0
  264. package/dist/rules/require-valid-agent-hooks.d.ts.map +1 -0
  265. package/dist/rules/require-valid-agent-hooks.js +86 -0
  266. package/dist/rules/require-valid-agent-hooks.js.map +1 -0
  267. package/dist/rules/require-valid-agent-invocation-controls.d.ts +4 -0
  268. package/dist/rules/require-valid-agent-invocation-controls.d.ts.map +1 -0
  269. package/dist/rules/require-valid-agent-invocation-controls.js +71 -0
  270. package/dist/rules/require-valid-agent-invocation-controls.js.map +1 -0
  271. package/dist/rules/require-valid-agent-mcp-servers.d.ts +4 -0
  272. package/dist/rules/require-valid-agent-mcp-servers.d.ts.map +1 -0
  273. package/dist/rules/require-valid-agent-mcp-servers.js +64 -0
  274. package/dist/rules/require-valid-agent-mcp-servers.js.map +1 -0
  275. package/dist/rules/require-valid-agent-model.d.ts +4 -0
  276. package/dist/rules/require-valid-agent-model.d.ts.map +1 -0
  277. package/dist/rules/require-valid-agent-model.js +64 -0
  278. package/dist/rules/require-valid-agent-model.js.map +1 -0
  279. package/dist/rules/require-valid-agent-name.d.ts +4 -0
  280. package/dist/rules/require-valid-agent-name.d.ts.map +1 -0
  281. package/dist/rules/require-valid-agent-name.js +51 -0
  282. package/dist/rules/require-valid-agent-name.js.map +1 -0
  283. package/dist/rules/require-valid-agent-subagents.d.ts +4 -0
  284. package/dist/rules/require-valid-agent-subagents.d.ts.map +1 -0
  285. package/dist/rules/require-valid-agent-subagents.js +79 -0
  286. package/dist/rules/require-valid-agent-subagents.js.map +1 -0
  287. package/dist/rules/require-valid-agent-target.d.ts +4 -0
  288. package/dist/rules/require-valid-agent-target.d.ts.map +1 -0
  289. package/dist/rules/require-valid-agent-target.js +62 -0
  290. package/dist/rules/require-valid-agent-target.js.map +1 -0
  291. package/dist/rules/require-valid-agent-tools.d.ts +4 -0
  292. package/dist/rules/require-valid-agent-tools.d.ts.map +1 -0
  293. package/dist/rules/require-valid-agent-tools.js +64 -0
  294. package/dist/rules/require-valid-agent-tools.js.map +1 -0
  295. package/dist/rules/require-valid-instructions-apply-to-globs.d.ts +4 -0
  296. package/dist/rules/require-valid-instructions-apply-to-globs.d.ts.map +1 -0
  297. package/dist/rules/require-valid-instructions-apply-to-globs.js +79 -0
  298. package/dist/rules/require-valid-instructions-apply-to-globs.js.map +1 -0
  299. package/dist/rules/require-valid-prompt-argument-hint.d.ts +4 -0
  300. package/dist/rules/require-valid-prompt-argument-hint.d.ts.map +1 -0
  301. package/dist/rules/require-valid-prompt-argument-hint.js +52 -0
  302. package/dist/rules/require-valid-prompt-argument-hint.js.map +1 -0
  303. package/dist/rules/require-valid-prompt-model.d.ts +4 -0
  304. package/dist/rules/require-valid-prompt-model.d.ts.map +1 -0
  305. package/dist/rules/require-valid-prompt-model.js +77 -0
  306. package/dist/rules/require-valid-prompt-model.js.map +1 -0
  307. package/dist/rules/require-valid-prompt-name.d.ts +4 -0
  308. package/dist/rules/require-valid-prompt-name.d.ts.map +1 -0
  309. package/dist/rules/require-valid-prompt-name.js +51 -0
  310. package/dist/rules/require-valid-prompt-name.js.map +1 -0
  311. package/dist/rules/require-valid-prompt-tools.d.ts +4 -0
  312. package/dist/rules/require-valid-prompt-tools.d.ts.map +1 -0
  313. package/dist/rules/require-valid-prompt-tools.js +64 -0
  314. package/dist/rules/require-valid-prompt-tools.js.map +1 -0
  315. package/dist/rules/require-valid-repository-hook-command-type.d.ts +4 -0
  316. package/dist/rules/require-valid-repository-hook-command-type.d.ts.map +1 -0
  317. package/dist/rules/require-valid-repository-hook-command-type.js +58 -0
  318. package/dist/rules/require-valid-repository-hook-command-type.js.map +1 -0
  319. package/dist/rules/require-valid-repository-hook-env.d.ts +4 -0
  320. package/dist/rules/require-valid-repository-hook-env.d.ts.map +1 -0
  321. package/dist/rules/require-valid-repository-hook-env.js +57 -0
  322. package/dist/rules/require-valid-repository-hook-env.js.map +1 -0
  323. package/dist/rules/require-valid-repository-hook-events.d.ts +4 -0
  324. package/dist/rules/require-valid-repository-hook-events.d.ts.map +1 -0
  325. package/dist/rules/require-valid-repository-hook-events.js +55 -0
  326. package/dist/rules/require-valid-repository-hook-events.js.map +1 -0
  327. package/dist/rules/require-valid-repository-hook-timeouts.d.ts +4 -0
  328. package/dist/rules/require-valid-repository-hook-timeouts.d.ts.map +1 -0
  329. package/dist/rules/require-valid-repository-hook-timeouts.js +59 -0
  330. package/dist/rules/require-valid-repository-hook-timeouts.js.map +1 -0
  331. package/dist/rules/require-valid-repository-hook-version.d.ts +4 -0
  332. package/dist/rules/require-valid-repository-hook-version.d.ts.map +1 -0
  333. package/dist/rules/require-valid-repository-hook-version.js +53 -0
  334. package/dist/rules/require-valid-repository-hook-version.js.map +1 -0
  335. package/dist/rules/require-valid-skill-directory-name.d.ts +4 -0
  336. package/dist/rules/require-valid-skill-directory-name.d.ts.map +1 -0
  337. package/dist/rules/require-valid-skill-directory-name.js +50 -0
  338. package/dist/rules/require-valid-skill-directory-name.js.map +1 -0
  339. package/dist/rules/require-valid-skill-license.d.ts +4 -0
  340. package/dist/rules/require-valid-skill-license.d.ts.map +1 -0
  341. package/dist/rules/require-valid-skill-license.js +47 -0
  342. package/dist/rules/require-valid-skill-license.js.map +1 -0
  343. package/dist/rules/require-valid-skill-name.d.ts +4 -0
  344. package/dist/rules/require-valid-skill-name.d.ts.map +1 -0
  345. package/dist/rules/require-valid-skill-name.js +57 -0
  346. package/dist/rules/require-valid-skill-name.js.map +1 -0
  347. package/docs/rules/getting-started.md +24 -0
  348. package/docs/rules/guides/copilot-customization-files.md +17 -0
  349. package/docs/rules/no-blank-customization-body.md +52 -0
  350. package/docs/rules/no-blank-repository-instructions.md +37 -0
  351. package/docs/rules/no-blank-skill-body.md +41 -0
  352. package/docs/rules/no-deprecated-agent-infer.md +42 -0
  353. package/docs/rules/no-duplicate-agent-names.md +36 -0
  354. package/docs/rules/no-duplicate-prompt-names.md +36 -0
  355. package/docs/rules/no-duplicate-skill-names.md +37 -0
  356. package/docs/rules/no-duplicate-slash-command-names.md +40 -0
  357. package/docs/rules/no-empty-repository-hook-arrays.md +44 -0
  358. package/docs/rules/no-legacy-chatmode-files.md +53 -0
  359. package/docs/rules/overview.md +27 -0
  360. package/docs/rules/prefer-custom-instructions-under-code-review-limit.md +39 -0
  361. package/docs/rules/prefer-fast-repository-hooks.md +43 -0
  362. package/docs/rules/prefer-qualified-tools.md +49 -0
  363. package/docs/rules/presets/all.md +82 -0
  364. package/docs/rules/presets/index.md +78 -0
  365. package/docs/rules/presets/minimal.md +16 -0
  366. package/docs/rules/presets/recommended.md +67 -0
  367. package/docs/rules/presets/strict.md +81 -0
  368. package/docs/rules/require-agent-tool-for-subagents.md +44 -0
  369. package/docs/rules/require-agents-md-for-cross-surface-agent-instructions.md +39 -0
  370. package/docs/rules/require-chatmode-file-metadata.md +41 -0
  371. package/docs/rules/require-existing-agent-hook-cwd.md +51 -0
  372. package/docs/rules/require-existing-agent-mcp-servers.md +43 -0
  373. package/docs/rules/require-existing-relative-agent-links.md +41 -0
  374. package/docs/rules/require-existing-relative-instructions-links.md +43 -0
  375. package/docs/rules/require-existing-relative-prompt-links.md +41 -0
  376. package/docs/rules/require-existing-relative-skill-links.md +44 -0
  377. package/docs/rules/require-existing-repository-hook-cwd.md +45 -0
  378. package/docs/rules/require-github-copilot-target-for-mcp-servers.md +46 -0
  379. package/docs/rules/require-instructions-apply-to.md +40 -0
  380. package/docs/rules/require-json-agent-mcp-servers.md +41 -0
  381. package/docs/rules/require-prompt-file-metadata.md +45 -0
  382. package/docs/rules/require-qualified-agent-handoff-models.md +47 -0
  383. package/docs/rules/require-relative-agent-hook-cwd.md +50 -0
  384. package/docs/rules/require-relative-agent-links.md +40 -0
  385. package/docs/rules/require-relative-instructions-links.md +42 -0
  386. package/docs/rules/require-relative-prompt-links.md +43 -0
  387. package/docs/rules/require-relative-repository-hook-cwd.md +43 -0
  388. package/docs/rules/require-relative-skill-links.md +42 -0
  389. package/docs/rules/require-repository-hook-arrays.md +33 -0
  390. package/docs/rules/require-repository-hook-command-shell.md +44 -0
  391. package/docs/rules/require-repository-hooks-object.md +34 -0
  392. package/docs/rules/require-repository-instructions-file.md +42 -0
  393. package/docs/rules/require-skill-file-location.md +33 -0
  394. package/docs/rules/require-skill-file-metadata.md +40 -0
  395. package/docs/rules/require-skill-md-filename.md +43 -0
  396. package/docs/rules/require-skill-name-match-directory.md +46 -0
  397. package/docs/rules/require-string-repository-hook-env-values.md +43 -0
  398. package/docs/rules/require-valid-agent-argument-hint.md +42 -0
  399. package/docs/rules/require-valid-agent-handoff-send.md +49 -0
  400. package/docs/rules/require-valid-agent-handoffs.md +51 -0
  401. package/docs/rules/require-valid-agent-hook-events.md +47 -0
  402. package/docs/rules/require-valid-agent-hook-timeouts.md +49 -0
  403. package/docs/rules/require-valid-agent-hooks.md +49 -0
  404. package/docs/rules/require-valid-agent-invocation-controls.md +45 -0
  405. package/docs/rules/require-valid-agent-mcp-servers.md +45 -0
  406. package/docs/rules/require-valid-agent-model.md +43 -0
  407. package/docs/rules/require-valid-agent-name.md +42 -0
  408. package/docs/rules/require-valid-agent-subagents.md +52 -0
  409. package/docs/rules/require-valid-agent-target.md +44 -0
  410. package/docs/rules/require-valid-agent-tools.md +43 -0
  411. package/docs/rules/require-valid-instructions-apply-to-globs.md +45 -0
  412. package/docs/rules/require-valid-prompt-argument-hint.md +42 -0
  413. package/docs/rules/require-valid-prompt-model.md +45 -0
  414. package/docs/rules/require-valid-prompt-name.md +42 -0
  415. package/docs/rules/require-valid-prompt-tools.md +43 -0
  416. package/docs/rules/require-valid-repository-hook-command-type.md +45 -0
  417. package/docs/rules/require-valid-repository-hook-env.md +43 -0
  418. package/docs/rules/require-valid-repository-hook-events.md +34 -0
  419. package/docs/rules/require-valid-repository-hook-timeouts.md +43 -0
  420. package/docs/rules/require-valid-repository-hook-version.md +34 -0
  421. package/docs/rules/require-valid-skill-directory-name.md +34 -0
  422. package/docs/rules/require-valid-skill-license.md +45 -0
  423. package/docs/rules/require-valid-skill-name.md +43 -0
  424. package/package.json +562 -0
@@ -0,0 +1,50 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * ESLint rule implementation for `require-repository-hooks-object`.
4
+ */
5
+ import { isRepositoryHookFilePath } from "../_internal/copilot-file-kind.js";
6
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
7
+ import { reportAtDocumentStart } from "../_internal/markdown-rule.js";
8
+ import { getRepositoryHooksValue, isJsonObject, parseJsonText, } from "../_internal/repository-hooks-json.js";
9
+ const requireRepositoryHooksObjectRule = createCopilotRule({
10
+ create(context) {
11
+ return {
12
+ Document() {
13
+ if (!isRepositoryHookFilePath(context.filename)) {
14
+ return;
15
+ }
16
+ const root = parseJsonText(context.sourceCode.text);
17
+ const hooksValue = getRepositoryHooksValue(root);
18
+ if (isJsonObject(hooksValue)) {
19
+ return;
20
+ }
21
+ reportAtDocumentStart(context, {
22
+ messageId: "invalidRepositoryHooksObject",
23
+ });
24
+ },
25
+ };
26
+ },
27
+ defaultOptions: [],
28
+ meta: {
29
+ deprecated: false,
30
+ docs: {
31
+ copilotConfigs: [
32
+ "copilot.configs.recommended",
33
+ "copilot.configs.strict",
34
+ "copilot.configs.all",
35
+ ],
36
+ description: "require repository hook configuration files to declare a top-level `hooks` object.",
37
+ frozen: false,
38
+ recommended: true,
39
+ requiresTypeChecking: false,
40
+ },
41
+ messages: {
42
+ invalidRepositoryHooksObject: "Repository hook configuration files must declare a top-level `hooks` object.",
43
+ },
44
+ schema: [],
45
+ type: "problem",
46
+ },
47
+ name: "require-repository-hooks-object",
48
+ });
49
+ export default requireRepositoryHooksObjectRule;
50
+ //# sourceMappingURL=require-repository-hooks-object.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-repository-hooks-object.js","sourceRoot":"","sources":["../../src/rules/require-repository-hooks-object.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EACH,uBAAuB,EACvB,YAAY,EACZ,aAAa,GAChB,MAAM,uCAAuC,CAAC;AAE/C,MAAM,gCAAgC,GAAsB,iBAAiB,CAAC;IAC1E,MAAM,CAAC,OAAO;QACV,OAAO;YACH,QAAQ;gBACJ,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC9C,OAAO;gBACX,CAAC;gBAED,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACpD,MAAM,UAAU,GAAG,uBAAuB,CAAC,IAAI,CAAC,CAAC;gBAEjD,IAAI,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC;oBAC3B,OAAO;gBACX,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,SAAS,EAAE,8BAA8B;iBAC5C,CAAC,CAAC;YACP,CAAC;SACJ,CAAC;IACN,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,oFAAoF;YACxF,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,4BAA4B,EACxB,8EAA8E;SACrF;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,iCAAiC;CAC1C,CAAC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireRepositoryInstructionsFileRule: CopilotRuleModule;
3
+ export default requireRepositoryInstructionsFileRule;
4
+ //# sourceMappingURL=require-repository-instructions-file.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-repository-instructions-file.d.ts","sourceRoot":"","sources":["../../src/rules/require-repository-instructions-file.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAY7E,QAAA,MAAM,qCAAqC,EAAE,iBAiDvC,CAAC;AAEP,eAAe,qCAAqC,CAAC"}
@@ -0,0 +1,50 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * ESLint rule implementation for `require-repository-instructions-file`.
4
+ */
5
+ import * as fs from "node:fs";
6
+ import { getCopilotFileKind, getRepositoryInstructionsPath, } from "../_internal/copilot-file-kind.js";
7
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
8
+ import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
9
+ const requireRepositoryInstructionsFileRule = createCopilotRule({
10
+ create(context) {
11
+ return createMarkdownDocumentListener(() => {
12
+ const fileKind = getCopilotFileKind(context.filename);
13
+ if (fileKind !== "agent-instructions" &&
14
+ fileKind !== "chatmode" &&
15
+ fileKind !== "instructions" &&
16
+ fileKind !== "prompt") {
17
+ return;
18
+ }
19
+ const repositoryInstructionsPath = getRepositoryInstructionsPath(context.filename);
20
+ if (fs.existsSync(repositoryInstructionsPath)) {
21
+ return;
22
+ }
23
+ reportAtDocumentStart(context, {
24
+ messageId: "missingRepositoryInstructions",
25
+ });
26
+ });
27
+ },
28
+ defaultOptions: [],
29
+ meta: {
30
+ deprecated: false,
31
+ docs: {
32
+ copilotConfigs: [
33
+ "copilot.configs.strict",
34
+ "copilot.configs.all",
35
+ ],
36
+ description: "require repositories that define Copilot customization assets to also provide `.github/copilot-instructions.md`.",
37
+ frozen: false,
38
+ recommended: false,
39
+ requiresTypeChecking: false,
40
+ },
41
+ messages: {
42
+ missingRepositoryInstructions: "Repositories that define Copilot prompts, custom agents, legacy chat modes, agent instructions, or path-specific instructions should also provide `.github/copilot-instructions.md` for baseline repository guidance.",
43
+ },
44
+ schema: [],
45
+ type: "suggestion",
46
+ },
47
+ name: "require-repository-instructions-file",
48
+ });
49
+ export default requireRepositoryInstructionsFileRule;
50
+ //# sourceMappingURL=require-repository-instructions-file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-repository-instructions-file.js","sourceRoot":"","sources":["../../src/rules/require-repository-instructions-file.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAI9B,OAAO,EACH,kBAAkB,EAClB,6BAA6B,GAChC,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,qCAAqC,GACvC,iBAAiB,CAAC;IACd,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,MAAM,QAAQ,GAAG,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAEtD,IACI,QAAQ,KAAK,oBAAoB;gBACjC,QAAQ,KAAK,UAAU;gBACvB,QAAQ,KAAK,cAAc;gBAC3B,QAAQ,KAAK,QAAQ,EACvB,CAAC;gBACC,OAAO;YACX,CAAC;YAED,MAAM,0BAA0B,GAC5B,6BAA6B,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAEpD,IAAI,EAAE,CAAC,UAAU,CAAC,0BAA0B,CAAC,EAAE,CAAC;gBAC5C,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,SAAS,EAAE,+BAA+B;aAC7C,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,kHAAkH;YACtH,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,6BAA6B,EACzB,uNAAuN;SAC9N;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,sCAAsC;CAC/C,CAAC,CAAC;AAEP,eAAe,qCAAqC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireSkillFileLocationRule: CopilotRuleModule;
3
+ export default requireSkillFileLocationRule;
4
+ //# sourceMappingURL=require-skill-file-location.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-file-location.d.ts","sourceRoot":"","sources":["../../src/rules/require-skill-file-location.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAS7E,QAAA,MAAM,4BAA4B,EAAE,iBAuClC,CAAC;AAEH,eAAe,4BAA4B,CAAC"}
@@ -0,0 +1,46 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * ESLint rule implementation for `require-skill-file-location`.
4
+ */
5
+ import * as path from "node:path";
6
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
7
+ import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
8
+ import { isValidSkillDefinitionLocation } from "../_internal/skill-files.js";
9
+ const requireSkillFileLocationRule = createCopilotRule({
10
+ create(context) {
11
+ return createMarkdownDocumentListener(() => {
12
+ if (path.basename(context.filename) !== "SKILL.md") {
13
+ return;
14
+ }
15
+ if (isValidSkillDefinitionLocation(context.filename)) {
16
+ return;
17
+ }
18
+ reportAtDocumentStart(context, {
19
+ messageId: "invalidSkillLocation",
20
+ });
21
+ });
22
+ },
23
+ defaultOptions: [],
24
+ meta: {
25
+ deprecated: false,
26
+ docs: {
27
+ copilotConfigs: [
28
+ "copilot.configs.recommended",
29
+ "copilot.configs.strict",
30
+ "copilot.configs.all",
31
+ ],
32
+ description: "require project skill definition files to live at a documented `.github/skills/<skill>/SKILL.md` or `.claude/skills/<skill>/SKILL.md` path.",
33
+ frozen: false,
34
+ recommended: true,
35
+ requiresTypeChecking: false,
36
+ },
37
+ messages: {
38
+ invalidSkillLocation: "Copilot skill definition files should live at `.github/skills/<skill>/SKILL.md` or `.claude/skills/<skill>/SKILL.md`.",
39
+ },
40
+ schema: [],
41
+ type: "problem",
42
+ },
43
+ name: "require-skill-file-location",
44
+ });
45
+ export default requireSkillFileLocationRule;
46
+ //# sourceMappingURL=require-skill-file-location.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-file-location.js","sourceRoot":"","sources":["../../src/rules/require-skill-file-location.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAIlC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,8BAA8B,EAAE,MAAM,6BAA6B,CAAC;AAE7E,MAAM,4BAA4B,GAAsB,iBAAiB,CAAC;IACtE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,UAAU,EAAE,CAAC;gBACjD,OAAO;YACX,CAAC;YAED,IAAI,8BAA8B,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACnD,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,SAAS,EAAE,sBAAsB;aACpC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,6IAA6I;YACjJ,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,oBAAoB,EAChB,uHAAuH;SAC9H;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,6BAA6B;CACtC,CAAC,CAAC;AAEH,eAAe,4BAA4B,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireSkillFileMetadataRule: CopilotRuleModule;
3
+ export default requireSkillFileMetadataRule;
4
+ //# sourceMappingURL=require-skill-file-metadata.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-file-metadata.d.ts","sourceRoot":"","sources":["../../src/rules/require-skill-file-metadata.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAiB7E,QAAA,MAAM,4BAA4B,EAAE,iBA2DlC,CAAC;AAEH,eAAe,4BAA4B,CAAC"}
@@ -0,0 +1,60 @@
1
+ import { isSkillFilePath } from "../_internal/copilot-file-kind.js";
2
+ /**
3
+ * @packageDocumentation
4
+ * ESLint rule implementation for `require-skill-file-metadata`.
5
+ */
6
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
7
+ import { extractFrontmatter, getFrontmatterScalar, } from "../_internal/frontmatter.js";
8
+ import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
9
+ const requireSkillFileMetadataRule = createCopilotRule({
10
+ create(context) {
11
+ return createMarkdownDocumentListener(() => {
12
+ if (!isSkillFilePath(context.filename)) {
13
+ return;
14
+ }
15
+ const frontmatter = extractFrontmatter(context.sourceCode.text);
16
+ if (frontmatter === null) {
17
+ reportAtDocumentStart(context, {
18
+ messageId: "missingSkillFrontmatter",
19
+ });
20
+ return;
21
+ }
22
+ if (getFrontmatterScalar(frontmatter, "name") === undefined) {
23
+ reportAtDocumentStart(context, {
24
+ messageId: "missingSkillName",
25
+ });
26
+ return;
27
+ }
28
+ if (getFrontmatterScalar(frontmatter, "description") === undefined) {
29
+ reportAtDocumentStart(context, {
30
+ messageId: "missingSkillDescription",
31
+ });
32
+ }
33
+ });
34
+ },
35
+ defaultOptions: [],
36
+ meta: {
37
+ deprecated: false,
38
+ docs: {
39
+ copilotConfigs: [
40
+ "copilot.configs.recommended",
41
+ "copilot.configs.strict",
42
+ "copilot.configs.all",
43
+ ],
44
+ description: "require Copilot skill definition files to declare `name` and `description` frontmatter.",
45
+ frozen: false,
46
+ recommended: true,
47
+ requiresTypeChecking: false,
48
+ },
49
+ messages: {
50
+ missingSkillDescription: "Copilot skill definition files must declare a non-empty `description` frontmatter value.",
51
+ missingSkillFrontmatter: "Copilot skill definition files must start with YAML frontmatter that declares at least `name` and `description`.",
52
+ missingSkillName: "Copilot skill definition files must declare a non-empty `name` frontmatter value.",
53
+ },
54
+ schema: [],
55
+ type: "problem",
56
+ },
57
+ name: "require-skill-file-metadata",
58
+ });
59
+ export default requireSkillFileMetadataRule;
60
+ //# sourceMappingURL=require-skill-file-metadata.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-file-metadata.js","sourceRoot":"","sources":["../../src/rules/require-skill-file-metadata.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,oBAAoB,GACvB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,4BAA4B,GAAsB,iBAAiB,CAAC;IACtE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACrC,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;gBACvB,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,SAAS,EAAE,yBAAyB;iBACvC,CAAC,CAAC;gBACH,OAAO;YACX,CAAC;YAED,IAAI,oBAAoB,CAAC,WAAW,EAAE,MAAM,CAAC,KAAK,SAAS,EAAE,CAAC;gBAC1D,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,SAAS,EAAE,kBAAkB;iBAChC,CAAC,CAAC;gBACH,OAAO;YACX,CAAC;YAED,IACI,oBAAoB,CAAC,WAAW,EAAE,aAAa,CAAC,KAAK,SAAS,EAChE,CAAC;gBACC,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,SAAS,EAAE,yBAAyB;iBACvC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,yFAAyF;YAC7F,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,uBAAuB,EACnB,0FAA0F;YAC9F,uBAAuB,EACnB,kHAAkH;YACtH,gBAAgB,EACZ,mFAAmF;SAC1F;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,6BAA6B;CACtC,CAAC,CAAC;AAEH,eAAe,4BAA4B,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireSkillMdFilenameRule: CopilotRuleModule;
3
+ export default requireSkillMdFilenameRule;
4
+ //# sourceMappingURL=require-skill-md-filename.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-md-filename.d.ts","sourceRoot":"","sources":["../../src/rules/require-skill-md-filename.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAkB7E,QAAA,MAAM,0BAA0B,EAAE,iBAkDhC,CAAC;AAEH,eAAe,0BAA0B,CAAC"}
@@ -0,0 +1,55 @@
1
+ import { isSkillMarkdownFilePath } from "../_internal/copilot-file-kind.js";
2
+ /**
3
+ * @packageDocumentation
4
+ * ESLint rule implementation for `require-skill-md-filename`.
5
+ */
6
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
7
+ import { extractFrontmatter } from "../_internal/frontmatter.js";
8
+ import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
9
+ import { getSkillFileBasename, looksLikeSkillDefinitionDocument, } from "../_internal/skill-files.js";
10
+ const requireSkillMdFilenameRule = createCopilotRule({
11
+ create(context) {
12
+ return createMarkdownDocumentListener(() => {
13
+ if (!isSkillMarkdownFilePath(context.filename)) {
14
+ return;
15
+ }
16
+ const basename = getSkillFileBasename(context.filename);
17
+ if (basename === "SKILL.md") {
18
+ return;
19
+ }
20
+ const frontmatter = extractFrontmatter(context.sourceCode.text);
21
+ if (!looksLikeSkillDefinitionDocument(frontmatter)) {
22
+ return;
23
+ }
24
+ reportAtDocumentStart(context, {
25
+ data: {
26
+ basename,
27
+ },
28
+ messageId: "invalidSkillDefinitionFilename",
29
+ });
30
+ });
31
+ },
32
+ defaultOptions: [],
33
+ meta: {
34
+ deprecated: false,
35
+ docs: {
36
+ copilotConfigs: [
37
+ "copilot.configs.recommended",
38
+ "copilot.configs.strict",
39
+ "copilot.configs.all",
40
+ ],
41
+ description: "require markdown files that declare skill-definition frontmatter to use the documented `SKILL.md` filename.",
42
+ frozen: false,
43
+ recommended: true,
44
+ requiresTypeChecking: false,
45
+ },
46
+ messages: {
47
+ invalidSkillDefinitionFilename: "Skill-definition markdown files should be named `SKILL.md`, not `{{basename}}`.",
48
+ },
49
+ schema: [],
50
+ type: "problem",
51
+ },
52
+ name: "require-skill-md-filename",
53
+ });
54
+ export default requireSkillMdFilenameRule;
55
+ //# sourceMappingURL=require-skill-md-filename.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-md-filename.js","sourceRoot":"","sources":["../../src/rules/require-skill-md-filename.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AAC5E;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EACH,oBAAoB,EACpB,gCAAgC,GACnC,MAAM,6BAA6B,CAAC;AAErC,MAAM,0BAA0B,GAAsB,iBAAiB,CAAC;IACpE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC7C,OAAO;YACX,CAAC;YAED,MAAM,QAAQ,GAAG,oBAAoB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAExD,IAAI,QAAQ,KAAK,UAAU,EAAE,CAAC;gBAC1B,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IAAI,CAAC,gCAAgC,CAAC,WAAW,CAAC,EAAE,CAAC;gBACjD,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,QAAQ;iBACX;gBACD,SAAS,EAAE,gCAAgC;aAC9C,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,6GAA6G;YACjH,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,8BAA8B,EAC1B,iFAAiF;SACxF;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,2BAA2B;CACpC,CAAC,CAAC;AAEH,eAAe,0BAA0B,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireSkillNameMatchDirectoryRule: CopilotRuleModule;
3
+ export default requireSkillNameMatchDirectoryRule;
4
+ //# sourceMappingURL=require-skill-name-match-directory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-name-match-directory.d.ts","sourceRoot":"","sources":["../../src/rules/require-skill-name-match-directory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAqB7E,QAAA,MAAM,kCAAkC,EAAE,iBAyDzC,CAAC;AAEF,eAAe,kCAAkC,CAAC"}
@@ -0,0 +1,59 @@
1
+ import { getSkillDirectoryName, getSkillName, } from "../_internal/copilot-customization-names.js";
2
+ import { isSkillFilePath } from "../_internal/copilot-file-kind.js";
3
+ /**
4
+ * @packageDocumentation
5
+ * ESLint rule implementation for `require-skill-name-match-directory`.
6
+ */
7
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
8
+ import { extractFrontmatter, getFrontmatterScalar, } from "../_internal/frontmatter.js";
9
+ import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
10
+ const requireSkillNameMatchDirectoryRule = createCopilotRule({
11
+ create(context) {
12
+ return createMarkdownDocumentListener(() => {
13
+ if (!isSkillFilePath(context.filename)) {
14
+ return;
15
+ }
16
+ const frontmatter = extractFrontmatter(context.sourceCode.text);
17
+ const explicitSkillName = frontmatter === null
18
+ ? undefined
19
+ : getFrontmatterScalar(frontmatter, "name");
20
+ if (explicitSkillName === undefined) {
21
+ return;
22
+ }
23
+ const skillName = getSkillName(context.filename, frontmatter);
24
+ const directoryName = getSkillDirectoryName(context.filename);
25
+ if (skillName === directoryName) {
26
+ return;
27
+ }
28
+ reportAtDocumentStart(context, {
29
+ data: {
30
+ directoryName,
31
+ name: skillName,
32
+ },
33
+ messageId: "skillNameDoesNotMatchDirectory",
34
+ });
35
+ });
36
+ },
37
+ defaultOptions: [],
38
+ meta: {
39
+ deprecated: false,
40
+ docs: {
41
+ copilotConfigs: [
42
+ "copilot.configs.strict",
43
+ "copilot.configs.all",
44
+ ],
45
+ description: "require Copilot skill `name` metadata to match the skill directory name.",
46
+ frozen: false,
47
+ recommended: false,
48
+ requiresTypeChecking: false,
49
+ },
50
+ messages: {
51
+ skillNameDoesNotMatchDirectory: "Copilot skill `name` value `{{name}}` should match its directory name `{{directoryName}}`.",
52
+ },
53
+ schema: [],
54
+ type: "problem",
55
+ },
56
+ name: "require-skill-name-match-directory",
57
+ });
58
+ export default requireSkillNameMatchDirectoryRule;
59
+ //# sourceMappingURL=require-skill-name-match-directory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-skill-name-match-directory.js","sourceRoot":"","sources":["../../src/rules/require-skill-name-match-directory.ts"],"names":[],"mappings":"AAEA,OAAO,EACH,qBAAqB,EACrB,YAAY,GACf,MAAM,6CAA6C,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,oBAAoB,GACvB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,kCAAkC,GAAsB,iBAAiB,CAC3E;IACI,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACrC,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAChE,MAAM,iBAAiB,GACnB,WAAW,KAAK,IAAI;gBAChB,CAAC,CAAC,SAAS;gBACX,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;YAEpD,IAAI,iBAAiB,KAAK,SAAS,EAAE,CAAC;gBAClC,OAAO;YACX,CAAC;YAED,MAAM,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;YAC9D,MAAM,aAAa,GAAG,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAE9D,IAAI,SAAS,KAAK,aAAa,EAAE,CAAC;gBAC9B,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,aAAa;oBACb,IAAI,EAAE,SAAS;iBAClB;gBACD,SAAS,EAAE,gCAAgC;aAC9C,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,0EAA0E;YAC9E,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,8BAA8B,EAC1B,4FAA4F;SACnG;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,oCAAoC;CAC7C,CACJ,CAAC;AAEF,eAAe,kCAAkC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireStringRepositoryHookEnvValuesRule: CopilotRuleModule;
3
+ export default requireStringRepositoryHookEnvValuesRule;
4
+ //# sourceMappingURL=require-string-repository-hook-env-values.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-string-repository-hook-env-values.d.ts","sourceRoot":"","sources":["../../src/rules/require-string-repository-hook-env-values.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAiB7E,QAAA,MAAM,wCAAwC,EAAE,iBA8D1C,CAAC;AAEP,eAAe,wCAAwC,CAAC"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * ESLint rule implementation for `require-string-repository-hook-env-values`.
4
+ */
5
+ import { isRepositoryHookFilePath } from "../_internal/copilot-file-kind.js";
6
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
7
+ import { reportAtDocumentStart } from "../_internal/markdown-rule.js";
8
+ import { formatJsonValue, getRepositoryHookObjects, isJsonObject, isJsonString, parseJsonText, } from "../_internal/repository-hooks-json.js";
9
+ const requireStringRepositoryHookEnvValuesRule = createCopilotRule({
10
+ create(context) {
11
+ return {
12
+ Document() {
13
+ if (!isRepositoryHookFilePath(context.filename)) {
14
+ return;
15
+ }
16
+ const root = parseJsonText(context.sourceCode.text);
17
+ const invalidHook = getRepositoryHookObjects(root).find(({ hook }) => {
18
+ const env = hook["env"];
19
+ return (isJsonObject(env) &&
20
+ Object.values(env).some((value) => !isJsonString(value)));
21
+ });
22
+ if (invalidHook === undefined) {
23
+ return;
24
+ }
25
+ const env = invalidHook.hook["env"];
26
+ reportAtDocumentStart(context, {
27
+ data: {
28
+ env: formatJsonValue(env),
29
+ eventName: invalidHook.eventName,
30
+ },
31
+ messageId: "nonStringRepositoryHookEnvValue",
32
+ });
33
+ },
34
+ };
35
+ },
36
+ defaultOptions: [],
37
+ meta: {
38
+ deprecated: false,
39
+ docs: {
40
+ copilotConfigs: [
41
+ "copilot.configs.recommended",
42
+ "copilot.configs.strict",
43
+ "copilot.configs.all",
44
+ ],
45
+ description: "require repository hook `env` objects to use string values.",
46
+ frozen: false,
47
+ recommended: true,
48
+ requiresTypeChecking: false,
49
+ },
50
+ messages: {
51
+ nonStringRepositoryHookEnvValue: "Repository hook `env` for `{{eventName}}` must use string values only (current value: `{{env}}`).",
52
+ },
53
+ schema: [],
54
+ type: "problem",
55
+ },
56
+ name: "require-string-repository-hook-env-values",
57
+ });
58
+ export default requireStringRepositoryHookEnvValuesRule;
59
+ //# sourceMappingURL=require-string-repository-hook-env-values.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-string-repository-hook-env-values.js","sourceRoot":"","sources":["../../src/rules/require-string-repository-hook-env-values.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EACH,eAAe,EACf,wBAAwB,EACxB,YAAY,EACZ,YAAY,EACZ,aAAa,GAChB,MAAM,uCAAuC,CAAC;AAE/C,MAAM,wCAAwC,GAC1C,iBAAiB,CAAC;IACd,MAAM,CAAC,OAAO;QACV,OAAO;YACH,QAAQ;gBACJ,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC9C,OAAO;gBACX,CAAC;gBAED,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACpD,MAAM,WAAW,GAAG,wBAAwB,CAAC,IAAI,CAAC,CAAC,IAAI,CACnD,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;oBACT,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;oBAExB,OAAO,CACH,YAAY,CAAC,GAAG,CAAC;wBACjB,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CACnB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAClC,CACJ,CAAC;gBACN,CAAC,CACJ,CAAC;gBAEF,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;oBAC5B,OAAO;gBACX,CAAC;gBAED,MAAM,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAEpC,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,GAAG,EAAE,eAAe,CAAC,GAAG,CAAC;wBACzB,SAAS,EAAE,WAAW,CAAC,SAAS;qBACnC;oBACD,SAAS,EAAE,iCAAiC;iBAC/C,CAAC,CAAC;YACP,CAAC;SACJ,CAAC;IACN,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,6DAA6D;YACjE,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,+BAA+B,EAC3B,mGAAmG;SAC1G;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,2CAA2C;CACpD,CAAC,CAAC;AAEP,eAAe,wCAAwC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireValidAgentArgumentHintRule: CopilotRuleModule;
3
+ export default requireValidAgentArgumentHintRule;
4
+ //# sourceMappingURL=require-valid-agent-argument-hint.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-valid-agent-argument-hint.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-argument-hint.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAkB7E,QAAA,MAAM,iCAAiC,EAAE,iBAkDvC,CAAC;AAEH,eAAe,iCAAiC,CAAC"}
@@ -0,0 +1,51 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * ESLint rule implementation for `require-valid-agent-argument-hint`.
4
+ */
5
+ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
6
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
7
+ import { extractFrontmatter, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
8
+ import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
9
+ const requireValidAgentArgumentHintRule = createCopilotRule({
10
+ create(context) {
11
+ return createMarkdownDocumentListener(() => {
12
+ if (!isCustomAgentFilePath(context.filename)) {
13
+ return;
14
+ }
15
+ const frontmatter = extractFrontmatter(context.sourceCode.text);
16
+ if (frontmatter === null ||
17
+ !hasFrontmatterField(frontmatter, "argument-hint")) {
18
+ return;
19
+ }
20
+ if (getFrontmatterScalar(frontmatter, "argument-hint") !== undefined) {
21
+ return;
22
+ }
23
+ reportAtDocumentStart(context, {
24
+ messageId: "invalidAgentArgumentHint",
25
+ });
26
+ });
27
+ },
28
+ defaultOptions: [],
29
+ meta: {
30
+ deprecated: false,
31
+ docs: {
32
+ copilotConfigs: [
33
+ "copilot.configs.recommended",
34
+ "copilot.configs.strict",
35
+ "copilot.configs.all",
36
+ ],
37
+ description: "require Copilot custom-agent `argument-hint` metadata to be a non-empty scalar when present.",
38
+ frozen: false,
39
+ recommended: true,
40
+ requiresTypeChecking: false,
41
+ },
42
+ messages: {
43
+ invalidAgentArgumentHint: "Copilot custom-agent `argument-hint` metadata must be a non-empty scalar when present.",
44
+ },
45
+ schema: [],
46
+ type: "problem",
47
+ },
48
+ name: "require-valid-agent-argument-hint",
49
+ });
50
+ export default requireValidAgentArgumentHintRule;
51
+ //# sourceMappingURL=require-valid-agent-argument-hint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-valid-agent-argument-hint.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-argument-hint.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,GACtB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,iCAAiC,GAAsB,iBAAiB,CAAC;IAC3E,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IACI,WAAW,KAAK,IAAI;gBACpB,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,EACpD,CAAC;gBACC,OAAO;YACX,CAAC;YAED,IACI,oBAAoB,CAAC,WAAW,EAAE,eAAe,CAAC,KAAK,SAAS,EAClE,CAAC;gBACC,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,SAAS,EAAE,0BAA0B;aACxC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,8FAA8F;YAClG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,wBAAwB,EACpB,wFAAwF;SAC/F;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,mCAAmC;CAC5C,CAAC,CAAC;AAEH,eAAe,iCAAiC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireValidAgentHandoffSendRule: CopilotRuleModule;
3
+ export default requireValidAgentHandoffSendRule;
4
+ //# sourceMappingURL=require-valid-agent-handoff-send.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-valid-agent-handoff-send.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoff-send.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAmB7E,QAAA,MAAM,gCAAgC,EAAE,iBAoEtC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
@@ -0,0 +1,67 @@
1
+ /**
2
+ * @packageDocumentation
3
+ * ESLint rule implementation for `require-valid-agent-handoff-send`.
4
+ */
5
+ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
6
+ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
7
+ import { extractFrontmatter, getFrontmatterObjectList, } from "../_internal/frontmatter.js";
8
+ import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
9
+ const VALID_BOOLEAN_FIELD_VALUES = new Set(["false", "true"]);
10
+ const requireValidAgentHandoffSendRule = createCopilotRule({
11
+ create(context) {
12
+ return createMarkdownDocumentListener(() => {
13
+ if (!isCustomAgentFilePath(context.filename)) {
14
+ return;
15
+ }
16
+ const frontmatter = extractFrontmatter(context.sourceCode.text);
17
+ if (frontmatter === null) {
18
+ return;
19
+ }
20
+ const handoffs = getFrontmatterObjectList(frontmatter, "handoffs");
21
+ if (handoffs === undefined || handoffs.length === 0) {
22
+ return;
23
+ }
24
+ for (const [index, handoff] of handoffs.entries()) {
25
+ const rawSend = handoff["send"];
26
+ if (rawSend === undefined) {
27
+ continue;
28
+ }
29
+ const normalizedSend = rawSend.trim().toLowerCase();
30
+ if (VALID_BOOLEAN_FIELD_VALUES.has(normalizedSend)) {
31
+ continue;
32
+ }
33
+ reportAtDocumentStart(context, {
34
+ data: {
35
+ handoffNumber: String(index + 1),
36
+ sendValue: rawSend.trim().length > 0 ? rawSend : "(empty)",
37
+ },
38
+ messageId: "invalidHandoffSend",
39
+ });
40
+ return;
41
+ }
42
+ });
43
+ },
44
+ defaultOptions: [],
45
+ meta: {
46
+ deprecated: false,
47
+ docs: {
48
+ copilotConfigs: [
49
+ "copilot.configs.recommended",
50
+ "copilot.configs.strict",
51
+ "copilot.configs.all",
52
+ ],
53
+ description: "require Copilot custom-agent handoff `send` values to use documented boolean metadata when present.",
54
+ frozen: false,
55
+ recommended: true,
56
+ requiresTypeChecking: false,
57
+ },
58
+ messages: {
59
+ invalidHandoffSend: "Copilot custom agent handoff #{{handoffNumber}} must use a boolean `send` value (`true` or `false`), not `{{sendValue}}`.",
60
+ },
61
+ schema: [],
62
+ type: "problem",
63
+ },
64
+ name: "require-valid-agent-handoff-send",
65
+ });
66
+ export default requireValidAgentHandoffSendRule;
67
+ //# sourceMappingURL=require-valid-agent-handoff-send.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"require-valid-agent-handoff-send.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoff-send.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,wBAAwB,GAC3B,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,0BAA0B,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;AAE9D,MAAM,gCAAgC,GAAsB,iBAAiB,CAAC;IAC1E,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;gBACvB,OAAO;YACX,CAAC;YAED,MAAM,QAAQ,GAAG,wBAAwB,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;YAEnE,IAAI,QAAQ,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAClD,OAAO;YACX,CAAC;YAED,KAAK,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC;gBAChD,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;gBAEhC,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;oBACxB,SAAS;gBACb,CAAC;gBAED,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAEpD,IAAI,0BAA0B,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC;oBACjD,SAAS;gBACb,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,aAAa,EAAE,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;wBAChC,SAAS,EACL,OAAO,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;qBACtD;oBACD,SAAS,EAAE,oBAAoB;iBAClC,CAAC,CAAC;gBAEH,OAAO;YACX,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,qGAAqG;YACzG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,kBAAkB,EACd,2HAA2H;SAClI;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,kCAAkC;CAC3C,CAAC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
2
+ declare const requireValidAgentHandoffsRule: CopilotRuleModule;
3
+ export default requireValidAgentHandoffsRule;
4
+ //# sourceMappingURL=require-valid-agent-handoffs.d.ts.map