eslint-plugin-copilot 1.0.8 → 1.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +71 -72
- package/dist/_internal/copilot-config-references.d.ts +1 -1
- package/dist/_internal/copilot-config-references.d.ts.map +1 -1
- package/dist/_internal/copilot-config-references.js +3 -1
- package/dist/_internal/copilot-config-references.js.map +1 -1
- package/dist/_internal/copilot-file-kind.d.ts.map +1 -1
- package/dist/_internal/copilot-file-kind.js +4 -3
- package/dist/_internal/copilot-file-kind.js.map +1 -1
- package/dist/_internal/create-copilot-rule.d.ts +4 -2
- package/dist/_internal/create-copilot-rule.d.ts.map +1 -1
- package/dist/_internal/create-copilot-rule.js.map +1 -1
- package/dist/_internal/file-system.d.ts.map +1 -1
- package/dist/_internal/file-system.js +31 -18
- package/dist/_internal/file-system.js.map +1 -1
- package/dist/_internal/frontmatter.d.ts +1 -1
- package/dist/_internal/frontmatter.d.ts.map +1 -1
- package/dist/_internal/frontmatter.js +151 -119
- package/dist/_internal/frontmatter.js.map +1 -1
- package/dist/_internal/markdown-links.d.ts.map +1 -1
- package/dist/_internal/markdown-links.js +3 -1
- package/dist/_internal/markdown-links.js.map +1 -1
- package/dist/_internal/markdown-rule.d.ts +2 -1
- package/dist/_internal/markdown-rule.d.ts.map +1 -1
- package/dist/_internal/markdown-rule.js.map +1 -1
- package/dist/_internal/repository-hooks-json.d.ts +5 -2
- package/dist/_internal/repository-hooks-json.d.ts.map +1 -1
- package/dist/_internal/repository-hooks-json.js +7 -6
- package/dist/_internal/repository-hooks-json.js.map +1 -1
- package/dist/_internal/rule-catalog.d.ts.map +1 -1
- package/dist/_internal/rule-catalog.js +2 -3
- package/dist/_internal/rule-catalog.js.map +1 -1
- package/dist/plugin.cjs +560 -633
- package/dist/plugin.cjs.map +4 -4
- package/dist/plugin.d.cts +2 -1
- package/dist/plugin.d.ts +2 -1
- package/dist/plugin.d.ts.map +1 -1
- package/dist/plugin.js +4 -3
- package/dist/plugin.js.map +1 -1
- package/dist/rules/no-blank-customization-body.d.ts +1 -0
- package/dist/rules/no-blank-customization-body.d.ts.map +1 -1
- package/dist/rules/no-blank-customization-body.js +3 -0
- package/dist/rules/no-blank-customization-body.js.map +1 -1
- package/dist/rules/no-blank-repository-instructions.d.ts +1 -0
- package/dist/rules/no-blank-repository-instructions.d.ts.map +1 -1
- package/dist/rules/no-blank-repository-instructions.js +3 -0
- package/dist/rules/no-blank-repository-instructions.js.map +1 -1
- package/dist/rules/no-blank-skill-body.d.ts +1 -0
- package/dist/rules/no-blank-skill-body.d.ts.map +1 -1
- package/dist/rules/no-blank-skill-body.js +3 -0
- package/dist/rules/no-blank-skill-body.js.map +1 -1
- package/dist/rules/no-deprecated-agent-infer.d.ts +1 -0
- package/dist/rules/no-deprecated-agent-infer.d.ts.map +1 -1
- package/dist/rules/no-deprecated-agent-infer.js +3 -0
- package/dist/rules/no-deprecated-agent-infer.js.map +1 -1
- package/dist/rules/no-duplicate-agent-names.d.ts +1 -0
- package/dist/rules/no-duplicate-agent-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-agent-names.js +6 -4
- package/dist/rules/no-duplicate-agent-names.js.map +1 -1
- package/dist/rules/no-duplicate-prompt-names.d.ts +1 -0
- package/dist/rules/no-duplicate-prompt-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-prompt-names.js +6 -4
- package/dist/rules/no-duplicate-prompt-names.js.map +1 -1
- package/dist/rules/no-duplicate-skill-names.d.ts +1 -0
- package/dist/rules/no-duplicate-skill-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-skill-names.js +6 -4
- package/dist/rules/no-duplicate-skill-names.js.map +1 -1
- package/dist/rules/no-duplicate-slash-command-names.d.ts +1 -0
- package/dist/rules/no-duplicate-slash-command-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-slash-command-names.js +6 -4
- package/dist/rules/no-duplicate-slash-command-names.js.map +1 -1
- package/dist/rules/no-empty-repository-hook-arrays.d.ts +1 -0
- package/dist/rules/no-empty-repository-hook-arrays.d.ts.map +1 -1
- package/dist/rules/no-empty-repository-hook-arrays.js +7 -3
- package/dist/rules/no-empty-repository-hook-arrays.js.map +1 -1
- package/dist/rules/no-legacy-chatmode-files.d.ts +1 -0
- package/dist/rules/no-legacy-chatmode-files.d.ts.map +1 -1
- package/dist/rules/no-legacy-chatmode-files.js +3 -0
- package/dist/rules/no-legacy-chatmode-files.js.map +1 -1
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts +1 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts.map +1 -1
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.js +3 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.js.map +1 -1
- package/dist/rules/prefer-fast-repository-hooks.d.ts +1 -0
- package/dist/rules/prefer-fast-repository-hooks.d.ts.map +1 -1
- package/dist/rules/prefer-fast-repository-hooks.js +5 -1
- package/dist/rules/prefer-fast-repository-hooks.js.map +1 -1
- package/dist/rules/prefer-qualified-tools.d.ts +1 -0
- package/dist/rules/prefer-qualified-tools.d.ts.map +1 -1
- package/dist/rules/prefer-qualified-tools.js +8 -3
- package/dist/rules/prefer-qualified-tools.js.map +1 -1
- package/dist/rules/require-agent-tool-for-subagents.d.ts +1 -0
- package/dist/rules/require-agent-tool-for-subagents.d.ts.map +1 -1
- package/dist/rules/require-agent-tool-for-subagents.js +6 -2
- package/dist/rules/require-agent-tool-for-subagents.js.map +1 -1
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts +1 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts.map +1 -1
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js +3 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js.map +1 -1
- package/dist/rules/require-chatmode-file-metadata.d.ts +1 -0
- package/dist/rules/require-chatmode-file-metadata.d.ts.map +1 -1
- package/dist/rules/require-chatmode-file-metadata.js +5 -1
- package/dist/rules/require-chatmode-file-metadata.js.map +1 -1
- package/dist/rules/require-existing-agent-hook-cwd.d.ts +1 -0
- package/dist/rules/require-existing-agent-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-existing-agent-hook-cwd.js +6 -2
- package/dist/rules/require-existing-agent-hook-cwd.js.map +1 -1
- package/dist/rules/require-existing-agent-mcp-servers.d.ts +1 -0
- package/dist/rules/require-existing-agent-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-existing-agent-mcp-servers.js +6 -2
- package/dist/rules/require-existing-agent-mcp-servers.js.map +1 -1
- package/dist/rules/require-existing-relative-agent-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-agent-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-agent-links.js +3 -0
- package/dist/rules/require-existing-relative-agent-links.js.map +1 -1
- package/dist/rules/require-existing-relative-instructions-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-instructions-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-instructions-links.js +3 -0
- package/dist/rules/require-existing-relative-instructions-links.js.map +1 -1
- package/dist/rules/require-existing-relative-prompt-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-prompt-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-prompt-links.js +3 -0
- package/dist/rules/require-existing-relative-prompt-links.js.map +1 -1
- package/dist/rules/require-existing-relative-skill-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-skill-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-skill-links.js +3 -0
- package/dist/rules/require-existing-relative-skill-links.js.map +1 -1
- package/dist/rules/require-existing-repository-hook-cwd.d.ts +1 -0
- package/dist/rules/require-existing-repository-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-existing-repository-hook-cwd.js +5 -1
- package/dist/rules/require-existing-repository-hook-cwd.js.map +1 -1
- package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts +1 -0
- package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-github-copilot-target-for-mcp-servers.js +5 -1
- package/dist/rules/require-github-copilot-target-for-mcp-servers.js.map +1 -1
- package/dist/rules/require-instructions-apply-to.d.ts +1 -0
- package/dist/rules/require-instructions-apply-to.d.ts.map +1 -1
- package/dist/rules/require-instructions-apply-to.js +5 -1
- package/dist/rules/require-instructions-apply-to.js.map +1 -1
- package/dist/rules/require-json-agent-mcp-servers.d.ts +1 -0
- package/dist/rules/require-json-agent-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-json-agent-mcp-servers.js +6 -2
- package/dist/rules/require-json-agent-mcp-servers.js.map +1 -1
- package/dist/rules/require-prompt-file-metadata.d.ts +1 -0
- package/dist/rules/require-prompt-file-metadata.d.ts.map +1 -1
- package/dist/rules/require-prompt-file-metadata.js +43 -32
- package/dist/rules/require-prompt-file-metadata.js.map +1 -1
- package/dist/rules/require-qualified-agent-handoff-models.d.ts +1 -0
- package/dist/rules/require-qualified-agent-handoff-models.d.ts.map +1 -1
- package/dist/rules/require-qualified-agent-handoff-models.js +6 -2
- package/dist/rules/require-qualified-agent-handoff-models.js.map +1 -1
- package/dist/rules/require-relative-agent-hook-cwd.d.ts +1 -0
- package/dist/rules/require-relative-agent-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-relative-agent-hook-cwd.js +6 -2
- package/dist/rules/require-relative-agent-hook-cwd.js.map +1 -1
- package/dist/rules/require-relative-agent-links.d.ts +1 -0
- package/dist/rules/require-relative-agent-links.d.ts.map +1 -1
- package/dist/rules/require-relative-agent-links.js +3 -0
- package/dist/rules/require-relative-agent-links.js.map +1 -1
- package/dist/rules/require-relative-instructions-links.d.ts +1 -0
- package/dist/rules/require-relative-instructions-links.d.ts.map +1 -1
- package/dist/rules/require-relative-instructions-links.js +3 -0
- package/dist/rules/require-relative-instructions-links.js.map +1 -1
- package/dist/rules/require-relative-prompt-links.d.ts +1 -0
- package/dist/rules/require-relative-prompt-links.d.ts.map +1 -1
- package/dist/rules/require-relative-prompt-links.js +3 -0
- package/dist/rules/require-relative-prompt-links.js.map +1 -1
- package/dist/rules/require-relative-repository-hook-cwd.d.ts +1 -0
- package/dist/rules/require-relative-repository-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-relative-repository-hook-cwd.js +5 -1
- package/dist/rules/require-relative-repository-hook-cwd.js.map +1 -1
- package/dist/rules/require-relative-skill-links.d.ts +1 -0
- package/dist/rules/require-relative-skill-links.d.ts.map +1 -1
- package/dist/rules/require-relative-skill-links.js +3 -0
- package/dist/rules/require-relative-skill-links.js.map +1 -1
- package/dist/rules/require-repository-hook-arrays.d.ts +1 -0
- package/dist/rules/require-repository-hook-arrays.d.ts.map +1 -1
- package/dist/rules/require-repository-hook-arrays.js +7 -3
- package/dist/rules/require-repository-hook-arrays.js.map +1 -1
- package/dist/rules/require-repository-hook-command-shell.d.ts +1 -0
- package/dist/rules/require-repository-hook-command-shell.d.ts.map +1 -1
- package/dist/rules/require-repository-hook-command-shell.js +5 -1
- package/dist/rules/require-repository-hook-command-shell.js.map +1 -1
- package/dist/rules/require-repository-hooks-object.d.ts +1 -0
- package/dist/rules/require-repository-hooks-object.d.ts.map +1 -1
- package/dist/rules/require-repository-hooks-object.js +3 -0
- package/dist/rules/require-repository-hooks-object.js.map +1 -1
- package/dist/rules/require-repository-instructions-file.d.ts +1 -0
- package/dist/rules/require-repository-instructions-file.d.ts.map +1 -1
- package/dist/rules/require-repository-instructions-file.js +3 -0
- package/dist/rules/require-repository-instructions-file.js.map +1 -1
- package/dist/rules/require-skill-file-location.d.ts +1 -0
- package/dist/rules/require-skill-file-location.d.ts.map +1 -1
- package/dist/rules/require-skill-file-location.js +3 -0
- package/dist/rules/require-skill-file-location.js.map +1 -1
- package/dist/rules/require-skill-file-metadata.d.ts +1 -0
- package/dist/rules/require-skill-file-metadata.d.ts.map +1 -1
- package/dist/rules/require-skill-file-metadata.js +6 -2
- package/dist/rules/require-skill-file-metadata.js.map +1 -1
- package/dist/rules/require-skill-md-filename.d.ts +1 -0
- package/dist/rules/require-skill-md-filename.d.ts.map +1 -1
- package/dist/rules/require-skill-md-filename.js +3 -0
- package/dist/rules/require-skill-md-filename.js.map +1 -1
- package/dist/rules/require-skill-name-match-directory.d.ts +1 -0
- package/dist/rules/require-skill-name-match-directory.d.ts.map +1 -1
- package/dist/rules/require-skill-name-match-directory.js +5 -1
- package/dist/rules/require-skill-name-match-directory.js.map +1 -1
- package/dist/rules/require-string-repository-hook-env-values.d.ts +1 -0
- package/dist/rules/require-string-repository-hook-env-values.d.ts.map +1 -1
- package/dist/rules/require-string-repository-hook-env-values.js +6 -2
- package/dist/rules/require-string-repository-hook-env-values.js.map +1 -1
- package/dist/rules/require-valid-agent-argument-hint.d.ts +1 -0
- package/dist/rules/require-valid-agent-argument-hint.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-argument-hint.js +5 -1
- package/dist/rules/require-valid-agent-argument-hint.js.map +1 -1
- package/dist/rules/require-valid-agent-handoff-send.d.ts +1 -0
- package/dist/rules/require-valid-agent-handoff-send.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-handoff-send.js +7 -3
- package/dist/rules/require-valid-agent-handoff-send.js.map +1 -1
- package/dist/rules/require-valid-agent-handoffs.d.ts +1 -0
- package/dist/rules/require-valid-agent-handoffs.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-handoffs.js +5 -1
- package/dist/rules/require-valid-agent-handoffs.js.map +1 -1
- package/dist/rules/require-valid-agent-hook-events.d.ts +1 -0
- package/dist/rules/require-valid-agent-hook-events.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-hook-events.js +6 -2
- package/dist/rules/require-valid-agent-hook-events.js.map +1 -1
- package/dist/rules/require-valid-agent-hook-timeouts.d.ts +1 -0
- package/dist/rules/require-valid-agent-hook-timeouts.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-hook-timeouts.js +6 -2
- package/dist/rules/require-valid-agent-hook-timeouts.js.map +1 -1
- package/dist/rules/require-valid-agent-hooks.d.ts +1 -0
- package/dist/rules/require-valid-agent-hooks.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-hooks.js +31 -21
- package/dist/rules/require-valid-agent-hooks.js.map +1 -1
- package/dist/rules/require-valid-agent-invocation-controls.d.ts +1 -0
- package/dist/rules/require-valid-agent-invocation-controls.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-invocation-controls.js +7 -3
- package/dist/rules/require-valid-agent-invocation-controls.js.map +1 -1
- package/dist/rules/require-valid-agent-mcp-servers.d.ts +1 -0
- package/dist/rules/require-valid-agent-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-mcp-servers.js +8 -4
- package/dist/rules/require-valid-agent-mcp-servers.js.map +1 -1
- package/dist/rules/require-valid-agent-model.d.ts +1 -0
- package/dist/rules/require-valid-agent-model.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-model.js +7 -3
- package/dist/rules/require-valid-agent-model.js.map +1 -1
- package/dist/rules/require-valid-agent-name.d.ts +1 -0
- package/dist/rules/require-valid-agent-name.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-name.js +5 -1
- package/dist/rules/require-valid-agent-name.js.map +1 -1
- package/dist/rules/require-valid-agent-subagents.d.ts +1 -0
- package/dist/rules/require-valid-agent-subagents.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-subagents.js +8 -4
- package/dist/rules/require-valid-agent-subagents.js.map +1 -1
- package/dist/rules/require-valid-agent-target.d.ts +1 -0
- package/dist/rules/require-valid-agent-target.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-target.js +6 -2
- package/dist/rules/require-valid-agent-target.js.map +1 -1
- package/dist/rules/require-valid-agent-tools.d.ts +1 -0
- package/dist/rules/require-valid-agent-tools.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-tools.js +8 -4
- package/dist/rules/require-valid-agent-tools.js.map +1 -1
- package/dist/rules/require-valid-instructions-apply-to-globs.d.ts +1 -0
- package/dist/rules/require-valid-instructions-apply-to-globs.d.ts.map +1 -1
- package/dist/rules/require-valid-instructions-apply-to-globs.js +8 -3
- package/dist/rules/require-valid-instructions-apply-to-globs.js.map +1 -1
- package/dist/rules/require-valid-prompt-argument-hint.d.ts +1 -0
- package/dist/rules/require-valid-prompt-argument-hint.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-argument-hint.js +6 -3
- package/dist/rules/require-valid-prompt-argument-hint.js.map +1 -1
- package/dist/rules/require-valid-prompt-model.d.ts +1 -0
- package/dist/rules/require-valid-prompt-model.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-model.js +9 -5
- package/dist/rules/require-valid-prompt-model.js.map +1 -1
- package/dist/rules/require-valid-prompt-name.d.ts +1 -0
- package/dist/rules/require-valid-prompt-name.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-name.js +5 -1
- package/dist/rules/require-valid-prompt-name.js.map +1 -1
- package/dist/rules/require-valid-prompt-tools.d.ts +1 -0
- package/dist/rules/require-valid-prompt-tools.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-tools.js +8 -4
- package/dist/rules/require-valid-prompt-tools.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-command-type.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-command-type.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-command-type.js +5 -1
- package/dist/rules/require-valid-repository-hook-command-type.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-env.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-env.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-env.js +6 -2
- package/dist/rules/require-valid-repository-hook-env.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-events.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-events.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-events.js +5 -1
- package/dist/rules/require-valid-repository-hook-events.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-timeouts.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-timeouts.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-timeouts.js +7 -3
- package/dist/rules/require-valid-repository-hook-timeouts.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-version.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-version.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-version.js +3 -0
- package/dist/rules/require-valid-repository-hook-version.js.map +1 -1
- package/dist/rules/require-valid-skill-directory-name.d.ts +1 -0
- package/dist/rules/require-valid-skill-directory-name.d.ts.map +1 -1
- package/dist/rules/require-valid-skill-directory-name.js +3 -0
- package/dist/rules/require-valid-skill-directory-name.js.map +1 -1
- package/dist/rules/require-valid-skill-license.d.ts +1 -0
- package/dist/rules/require-valid-skill-license.d.ts.map +1 -1
- package/dist/rules/require-valid-skill-license.js +5 -1
- package/dist/rules/require-valid-skill-license.js.map +1 -1
- package/dist/rules/require-valid-skill-name.d.ts +1 -0
- package/dist/rules/require-valid-skill-name.d.ts.map +1 -1
- package/dist/rules/require-valid-skill-name.js +5 -1
- package/dist/rules/require-valid-skill-name.js.map +1 -1
- package/package.json +37 -277
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-empty-repository-hook-arrays.js","sourceRoot":"","sources":["../../src/rules/no-empty-repository-hook-arrays.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"no-empty-repository-hook-arrays.js","sourceRoot":"","sources":["../../src/rules/no-empty-repository-hook-arrays.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAI3D;;;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,6BAA6B,EAC7B,WAAW,EACX,aAAa,GAChB,MAAM,uCAAuC,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,yDAAyD;AACzD,MAAM,+BAA+B,GAAsB,iBAAiB,CAAC;IACzE,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,6BAA6B,CAAC,IAAI,CAAC,CAAC,IAAI,CACvD,CAAC,CAAC,EAAE,UAAU,CAAC,EAAE,EAAE,CACf,WAAW,CAAC,UAAU,CAAC,IAAI,OAAO,CAAC,UAAU,CAAC,CACrD,CAAC;gBAEF,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC;oBACzB,OAAO;gBACX,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,SAAS,EAAE,UAAU,CAAC,UAAU,CAAC;qBACpC;oBACD,SAAS,EAAE,0BAA0B;iBACxC,CAAC,CAAC;YACP,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE,CAAC,wBAAwB,EAAE,qBAAqB,CAAC;YACjE,WAAW,EACP,4FAA4F;YAChG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,iCAAiC,CAAC;SAC5D;QACD,QAAQ,EAAE;YACN,wBAAwB,EACpB,mFAAmF;SAC1F;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,iCAAiC;CAC1C,CAAC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `no-legacy-chatmode-files`. */
|
|
2
3
|
declare const noLegacyChatmodeFilesRule: CopilotRuleModule;
|
|
3
4
|
export default noLegacyChatmodeFilesRule;
|
|
4
5
|
//# sourceMappingURL=no-legacy-chatmode-files.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-legacy-chatmode-files.d.ts","sourceRoot":"","sources":["../../src/rules/no-legacy-chatmode-files.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"no-legacy-chatmode-files.d.ts","sourceRoot":"","sources":["../../src/rules/no-legacy-chatmode-files.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAc7E,kDAAkD;AAClD,QAAA,MAAM,yBAAyB,EAAE,iBAmC/B,CAAC;AAEH,eAAe,yBAAyB,CAAC"}
|
|
@@ -5,6 +5,8 @@
|
|
|
5
5
|
import { isLegacyChatmodeFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
6
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
7
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
8
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
9
|
+
/** Rule module for `no-legacy-chatmode-files`. */
|
|
8
10
|
const noLegacyChatmodeFilesRule = createCopilotRule({
|
|
9
11
|
create(context) {
|
|
10
12
|
return createMarkdownDocumentListener(() => {
|
|
@@ -28,6 +30,7 @@ const noLegacyChatmodeFilesRule = createCopilotRule({
|
|
|
28
30
|
frozen: false,
|
|
29
31
|
recommended: true,
|
|
30
32
|
requiresTypeChecking: false,
|
|
33
|
+
url: createRuleDocsUrl("no-legacy-chatmode-files"),
|
|
31
34
|
},
|
|
32
35
|
messages: {
|
|
33
36
|
legacyChatmodeFile: "Legacy Copilot `.chatmode.md` files should be migrated to `.github/agents/*.agent.md` custom agents.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-legacy-chatmode-files.js","sourceRoot":"","sources":["../../src/rules/no-legacy-chatmode-files.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;
|
|
1
|
+
{"version":3,"file":"no-legacy-chatmode-files.js","sourceRoot":"","sources":["../../src/rules/no-legacy-chatmode-files.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,kDAAkD;AAClD,MAAM,yBAAyB,GAAsB,iBAAiB,CAAC;IACnE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC9C,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,SAAS,EAAE,oBAAoB;aAClC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,4FAA4F;YAChG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,0BAA0B,CAAC;SACrD;QACD,QAAQ,EAAE;YACN,kBAAkB,EACd,sGAAsG;SAC7G;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,0BAA0B;CACnC,CAAC,CAAC;AAEH,eAAe,yBAAyB,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `prefer-custom-instructions-under-code-review-limit`. */
|
|
2
3
|
declare const preferCustomInstructionsUnderCodeReviewLimitRule: CopilotRuleModule;
|
|
3
4
|
export default preferCustomInstructionsUnderCodeReviewLimitRule;
|
|
4
5
|
//# sourceMappingURL=prefer-custom-instructions-under-code-review-limit.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-custom-instructions-under-code-review-limit.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-custom-instructions-under-code-review-limit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"prefer-custom-instructions-under-code-review-limit.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-custom-instructions-under-code-review-limit.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAgB7E,4EAA4E;AAC5E,QAAA,MAAM,gDAAgD,EAAE,iBAsDlD,CAAC;AAEP,eAAe,gDAAgD,CAAC"}
|
|
@@ -5,7 +5,9 @@ import { getCopilotFileKind } from "../_internal/copilot-file-kind.js";
|
|
|
5
5
|
*/
|
|
6
6
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
7
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
8
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
8
9
|
const CODE_REVIEW_CUSTOM_INSTRUCTIONS_LIMIT = 4000;
|
|
10
|
+
/** Rule module for `prefer-custom-instructions-under-code-review-limit`. */
|
|
9
11
|
const preferCustomInstructionsUnderCodeReviewLimitRule = createCopilotRule({
|
|
10
12
|
create(context) {
|
|
11
13
|
return createMarkdownDocumentListener(() => {
|
|
@@ -38,6 +40,7 @@ const preferCustomInstructionsUnderCodeReviewLimitRule = createCopilotRule({
|
|
|
38
40
|
frozen: false,
|
|
39
41
|
recommended: false,
|
|
40
42
|
requiresTypeChecking: false,
|
|
43
|
+
url: createRuleDocsUrl("prefer-custom-instructions-under-code-review-limit"),
|
|
41
44
|
},
|
|
42
45
|
messages: {
|
|
43
46
|
exceedsCodeReviewLimit: "Copilot code review only reads roughly the first {{maxCharacters}} characters of custom instructions; this file is {{characterCount}} characters long.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-custom-instructions-under-code-review-limit.js","sourceRoot":"","sources":["../../src/rules/prefer-custom-instructions-under-code-review-limit.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;
|
|
1
|
+
{"version":3,"file":"prefer-custom-instructions-under-code-review-limit.js","sourceRoot":"","sources":["../../src/rules/prefer-custom-instructions-under-code-review-limit.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,MAAM,qCAAqC,GAAG,IAAI,CAAC;AAEnD,4EAA4E;AAC5E,MAAM,gDAAgD,GAClD,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,cAAc;gBAC3B,QAAQ,KAAK,yBAAyB,EACxC,CAAC;gBACC,OAAO;YACX,CAAC;YAED,MAAM,cAAc,GAAG,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC;YAEtD,IAAI,cAAc,IAAI,qCAAqC,EAAE,CAAC;gBAC1D,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,cAAc,EAAE,MAAM,CAAC,cAAc,CAAC;oBACtC,aAAa,EAAE,MAAM,CACjB,qCAAqC,CACxC;iBACJ;gBACD,SAAS,EAAE,wBAAwB;aACtC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,mIAAmI;YACvI,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAClB,oDAAoD,CACvD;SACJ;QACD,QAAQ,EAAE;YACN,sBAAsB,EAClB,wJAAwJ;SAC/J;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,oDAAoD;CAC7D,CAAC,CAAC;AAEP,eAAe,gDAAgD,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `prefer-fast-repository-hooks`. */
|
|
2
3
|
declare const preferFastRepositoryHooksRule: CopilotRuleModule;
|
|
3
4
|
export default preferFastRepositoryHooksRule;
|
|
4
5
|
//# sourceMappingURL=prefer-fast-repository-hooks.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-fast-repository-hooks.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-fast-repository-hooks.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prefer-fast-repository-hooks.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-fast-repository-hooks.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAiB7E,sDAAsD;AACtD,QAAA,MAAM,6BAA6B,EAAE,iBA2DnC,CAAC;AAEH,eAAe,6BAA6B,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `prefer-fast-repository-hooks`.
|
|
@@ -6,6 +7,8 @@ import { isRepositoryHookFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { reportAtDocumentStart } from "../_internal/markdown-rule.js";
|
|
8
9
|
import { DEFAULT_REPOSITORY_HOOK_TIMEOUT_SECONDS, getRepositoryHookObjects, isJsonNumber, parseJsonText, } from "../_internal/repository-hooks-json.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
/** Rule module for `prefer-fast-repository-hooks`. */
|
|
9
12
|
const preferFastRepositoryHooksRule = createCopilotRule({
|
|
10
13
|
create(context) {
|
|
11
14
|
return {
|
|
@@ -19,7 +22,7 @@ const preferFastRepositoryHooksRule = createCopilotRule({
|
|
|
19
22
|
return (isJsonNumber(timeout) &&
|
|
20
23
|
timeout > DEFAULT_REPOSITORY_HOOK_TIMEOUT_SECONDS);
|
|
21
24
|
});
|
|
22
|
-
if (slowHook
|
|
25
|
+
if (!isDefined(slowHook)) {
|
|
23
26
|
return;
|
|
24
27
|
}
|
|
25
28
|
const timeout = slowHook.hook["timeoutSec"];
|
|
@@ -44,6 +47,7 @@ const preferFastRepositoryHooksRule = createCopilotRule({
|
|
|
44
47
|
frozen: false,
|
|
45
48
|
recommended: false,
|
|
46
49
|
requiresTypeChecking: false,
|
|
50
|
+
url: createRuleDocsUrl("prefer-fast-repository-hooks"),
|
|
47
51
|
},
|
|
48
52
|
messages: {
|
|
49
53
|
slowRepositoryHookTimeout: "Repository hook `timeoutSec` for `{{eventName}}` is {{timeout}} seconds, which exceeds the default 30-second timeout budget.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-fast-repository-hooks.js","sourceRoot":"","sources":["../../src/rules/prefer-fast-repository-hooks.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prefer-fast-repository-hooks.js","sourceRoot":"","sources":["../../src/rules/prefer-fast-repository-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAItC;;;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,uCAAuC,EACvC,wBAAwB,EACxB,YAAY,EACZ,aAAa,GAChB,MAAM,uCAAuC,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,sDAAsD;AACtD,MAAM,6BAA6B,GAAsB,iBAAiB,CAAC;IACvE,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,QAAQ,GAAG,wBAAwB,CAAC,IAAI,CAAC,CAAC,IAAI,CAChD,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;oBACT,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;oBAEnC,OAAO,CACH,YAAY,CAAC,OAAO,CAAC;wBACrB,OAAO,GAAG,uCAAuC,CACpD,CAAC;gBACN,CAAC,CACJ,CAAC;gBAEF,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACvB,OAAO;gBACX,CAAC;gBAED,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAE5C,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC;oBACzB,OAAO;gBACX,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,SAAS,EAAE,QAAQ,CAAC,SAAS;wBAC7B,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC;qBAC3B;oBACD,SAAS,EAAE,2BAA2B;iBACzC,CAAC,CAAC;YACP,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE,CAAC,wBAAwB,EAAE,qBAAqB,CAAC;YACjE,WAAW,EACP,qHAAqH;YACzH,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,8BAA8B,CAAC;SACzD;QACD,QAAQ,EAAE;YACN,yBAAyB,EACrB,8HAA8H;SACrI;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,8BAA8B;CACvC,CAAC,CAAC;AAEH,eAAe,6BAA6B,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `prefer-qualified-tools`. */
|
|
2
3
|
declare const preferQualifiedToolsRule: CopilotRuleModule;
|
|
3
4
|
export default preferQualifiedToolsRule;
|
|
4
5
|
//# sourceMappingURL=prefer-qualified-tools.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-qualified-tools.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-qualified-tools.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prefer-qualified-tools.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-qualified-tools.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AA0B7E,gDAAgD;AAChD,QAAA,MAAM,wBAAwB,EAAE,iBAyD9B,CAAC;AAEH,eAAe,wBAAwB,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined, setHas } from "ts-extras";
|
|
1
2
|
import { getCopilotFileKind } from "../_internal/copilot-file-kind.js";
|
|
2
3
|
/**
|
|
3
4
|
* @packageDocumentation
|
|
@@ -6,8 +7,11 @@ import { getCopilotFileKind } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterList, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
9
11
|
const isQualifiedToolName = (toolName) => toolName.includes("/");
|
|
10
12
|
const allowedUnqualifiedToolNames = new Set(["agent", "runSubagent"]);
|
|
13
|
+
const isAllowedUnqualifiedToolName = (toolName) => setHas(allowedUnqualifiedToolNames, toolName);
|
|
14
|
+
/** Rule module for `prefer-qualified-tools`. */
|
|
11
15
|
const preferQualifiedToolsRule = createCopilotRule({
|
|
12
16
|
create(context) {
|
|
13
17
|
return createMarkdownDocumentListener(() => {
|
|
@@ -20,12 +24,12 @@ const preferQualifiedToolsRule = createCopilotRule({
|
|
|
20
24
|
return;
|
|
21
25
|
}
|
|
22
26
|
const tools = getFrontmatterList(frontmatter, "tools");
|
|
23
|
-
if (tools
|
|
27
|
+
if (!isDefined(tools)) {
|
|
24
28
|
return;
|
|
25
29
|
}
|
|
26
30
|
const firstUnqualifiedTool = tools.find((toolName) => !isQualifiedToolName(toolName) &&
|
|
27
|
-
!
|
|
28
|
-
if (firstUnqualifiedTool ===
|
|
31
|
+
!isAllowedUnqualifiedToolName(toolName)) ?? null;
|
|
32
|
+
if (firstUnqualifiedTool === null) {
|
|
29
33
|
return;
|
|
30
34
|
}
|
|
31
35
|
reportAtDocumentStart(context, {
|
|
@@ -42,6 +46,7 @@ const preferQualifiedToolsRule = createCopilotRule({
|
|
|
42
46
|
frozen: false,
|
|
43
47
|
recommended: false,
|
|
44
48
|
requiresTypeChecking: false,
|
|
49
|
+
url: createRuleDocsUrl("prefer-qualified-tools"),
|
|
45
50
|
},
|
|
46
51
|
messages: {
|
|
47
52
|
preferQualifiedTool: "Prefer fully-qualified Copilot tool names in `tools` metadata when a documented built-in alias is not required. `{{toolName}}` should include a provider or tool-set prefix such as `search/codebase`.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-qualified-tools.js","sourceRoot":"","sources":["../../src/rules/prefer-qualified-tools.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prefer-qualified-tools.js","sourceRoot":"","sources":["../../src/rules/prefer-qualified-tools.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAI9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,kBAAkB,GACrB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,MAAM,mBAAmB,GAAG,CAAC,QAAgB,EAAW,EAAE,CACtD,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AAE3B,MAAM,2BAA2B,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;AAEtE,MAAM,4BAA4B,GAAG,CAAC,QAAgB,EAAW,EAAE,CAC/D,MAAM,CAAC,2BAA2B,EAAE,QAAQ,CAAC,CAAC;AAElD,gDAAgD;AAChD,MAAM,wBAAwB,GAAsB,iBAAiB,CAAC;IAClE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,MAAM,QAAQ,GAAG,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAEtD,IAAI,QAAQ,KAAK,UAAU,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;gBACnD,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,KAAK,GAAG,kBAAkB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAEvD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;gBACpB,OAAO;YACX,CAAC;YAED,MAAM,oBAAoB,GACtB,KAAK,CAAC,IAAI,CACN,CAAC,QAAQ,EAAE,EAAE,CACT,CAAC,mBAAmB,CAAC,QAAQ,CAAC;gBAC9B,CAAC,4BAA4B,CAAC,QAAQ,CAAC,CAC9C,IAAI,IAAI,CAAC;YAEd,IAAI,oBAAoB,KAAK,IAAI,EAAE,CAAC;gBAChC,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE,EAAE,QAAQ,EAAE,oBAAoB,EAAE;gBACxC,SAAS,EAAE,qBAAqB;aACnC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE,CAAC,qBAAqB,CAAC;YACvC,WAAW,EACP,mGAAmG;YACvG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,wBAAwB,CAAC;SACnD;QACD,QAAQ,EAAE;YACN,mBAAmB,EACf,wMAAwM;SAC/M;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,YAAY;KACrB;IACD,IAAI,EAAE,wBAAwB;CACjC,CAAC,CAAC;AAEH,eAAe,wBAAwB,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-agent-tool-for-subagents`. */
|
|
2
3
|
declare const requireAgentToolForSubagentsRule: CopilotRuleModule;
|
|
3
4
|
export default requireAgentToolForSubagentsRule;
|
|
4
5
|
//# sourceMappingURL=require-agent-tool-for-subagents.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-agent-tool-for-subagents.d.ts","sourceRoot":"","sources":["../../src/rules/require-agent-tool-for-subagents.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-agent-tool-for-subagents.d.ts","sourceRoot":"","sources":["../../src/rules/require-agent-tool-for-subagents.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAyB7E,0DAA0D;AAC1D,QAAA,MAAM,gCAAgC,EAAE,iBAiEtC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { arrayAt, isDefined, isEmpty, stringSplit } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-agent-tool-for-subagents`.
|
|
@@ -6,7 +7,9 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterList, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
-
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
const hasAgentTool = (tools) => tools?.some((toolName) => arrayAt(stringSplit(toolName, "/"), -1) === "agent") ?? false;
|
|
12
|
+
/** Rule module for `require-agent-tool-for-subagents`. */
|
|
10
13
|
const requireAgentToolForSubagentsRule = createCopilotRule({
|
|
11
14
|
create(context) {
|
|
12
15
|
return createMarkdownDocumentListener(() => {
|
|
@@ -23,7 +26,7 @@ const requireAgentToolForSubagentsRule = createCopilotRule({
|
|
|
23
26
|
const allowedAgents = getFrontmatterList(frontmatter, "agents");
|
|
24
27
|
const agentsScalar = getFrontmatterScalar(frontmatter, "agents");
|
|
25
28
|
if (agentsScalar !== "*" &&
|
|
26
|
-
(allowedAgents
|
|
29
|
+
(!isDefined(allowedAgents) || isEmpty(allowedAgents))) {
|
|
27
30
|
return;
|
|
28
31
|
}
|
|
29
32
|
const tools = getFrontmatterList(frontmatter, "tools");
|
|
@@ -49,6 +52,7 @@ const requireAgentToolForSubagentsRule = createCopilotRule({
|
|
|
49
52
|
frozen: false,
|
|
50
53
|
recommended: true,
|
|
51
54
|
requiresTypeChecking: false,
|
|
55
|
+
url: createRuleDocsUrl("require-agent-tool-for-subagents"),
|
|
52
56
|
},
|
|
53
57
|
messages: {
|
|
54
58
|
missingAgentTool: "Copilot custom agent files that declare `agents` must include the `agent` tool in `tools`.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-agent-tool-for-subagents.js","sourceRoot":"","sources":["../../src/rules/require-agent-tool-for-subagents.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-agent-tool-for-subagents.js","sourceRoot":"","sources":["../../src/rules/require-agent-tool-for-subagents.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAIrE;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,GACtB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,MAAM,YAAY,GAAG,CAAC,KAAoC,EAAW,EAAE,CACnE,KAAK,EAAE,IAAI,CACP,CAAC,QAAQ,EAAE,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,OAAO,CACpE,IAAI,KAAK,CAAC;AAEf,0DAA0D;AAC1D,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,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,QAAQ,CAAC,EAAE,CAAC;gBAC9C,OAAO;YACX,CAAC;YAED,MAAM,aAAa,GAAG,kBAAkB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAChE,MAAM,YAAY,GAAG,oBAAoB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAEjE,IACI,YAAY,KAAK,GAAG;gBACpB,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,OAAO,CAAC,aAAa,CAAC,CAAC,EACvD,CAAC;gBACC,OAAO;YACX,CAAC;YAED,MAAM,KAAK,GAAG,kBAAkB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAEvD,IAAI,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC;gBACtB,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,SAAS,EAAE,mBAAmB,CAAC,WAAW,EAAE,OAAO,CAAC;oBAChD,CAAC,CAAC,kBAAkB;oBACpB,CAAC,CAAC,cAAc;aACvB,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,gFAAgF;YACpF,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,kCAAkC,CAAC;SAC7D;QACD,QAAQ,EAAE;YACN,gBAAgB,EACZ,4FAA4F;YAChG,YAAY,EACR,mHAAmH;SAC1H;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,kCAAkC;CAC3C,CAAC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-agents-md-for-cross-surface-agent-instructions`. */
|
|
2
3
|
declare const requireAgentsMdForCrossSurfaceAgentInstructionsRule: CopilotRuleModule;
|
|
3
4
|
export default requireAgentsMdForCrossSurfaceAgentInstructionsRule;
|
|
4
5
|
//# sourceMappingURL=require-agents-md-for-cross-surface-agent-instructions.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-agents-md-for-cross-surface-agent-instructions.d.ts","sourceRoot":"","sources":["../../src/rules/require-agents-md-for-cross-surface-agent-instructions.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"require-agents-md-for-cross-surface-agent-instructions.d.ts","sourceRoot":"","sources":["../../src/rules/require-agents-md-for-cross-surface-agent-instructions.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAU7E,gFAAgF;AAChF,QAAA,MAAM,mDAAmD,EAAE,iBAmDrD,CAAC;AAEP,eAAe,mDAAmD,CAAC"}
|
|
@@ -6,6 +6,8 @@ import * as path from "node:path";
|
|
|
6
6
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
7
|
import { pathExists } from "../_internal/file-system.js";
|
|
8
8
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
10
|
+
/** Rule module for `require-agents-md-for-cross-surface-agent-instructions`. */
|
|
9
11
|
const requireAgentsMdForCrossSurfaceAgentInstructionsRule = createCopilotRule({
|
|
10
12
|
create(context) {
|
|
11
13
|
return createMarkdownDocumentListener(() => {
|
|
@@ -36,6 +38,7 @@ const requireAgentsMdForCrossSurfaceAgentInstructionsRule = createCopilotRule({
|
|
|
36
38
|
frozen: false,
|
|
37
39
|
recommended: false,
|
|
38
40
|
requiresTypeChecking: false,
|
|
41
|
+
url: createRuleDocsUrl("require-agents-md-for-cross-surface-agent-instructions"),
|
|
39
42
|
},
|
|
40
43
|
messages: {
|
|
41
44
|
missingAgentsMdSibling: "`{{basename}}` is less portable across Copilot surfaces without a sibling `AGENTS.md` file in the same directory.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-agents-md-for-cross-surface-agent-instructions.js","sourceRoot":"","sources":["../../src/rules/require-agents-md-for-cross-surface-agent-instructions.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAIlC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;
|
|
1
|
+
{"version":3,"file":"require-agents-md-for-cross-surface-agent-instructions.js","sourceRoot":"","sources":["../../src/rules/require-agents-md-for-cross-surface-agent-instructions.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAIlC,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,gFAAgF;AAChF,MAAM,mDAAmD,GACrD,iBAAiB,CAAC;IACd,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAEjD,IAAI,QAAQ,KAAK,WAAW,IAAI,QAAQ,KAAK,WAAW,EAAE,CAAC;gBACvD,OAAO;YACX,CAAC;YAED,MAAM,mBAAmB,GAAG,IAAI,CAAC,IAAI,CACjC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,EAC9B,WAAW,CACd,CAAC;YAEF,IAAI,UAAU,CAAC,mBAAmB,CAAC,EAAE,CAAC;gBAClC,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,QAAQ;iBACX;gBACD,SAAS,EAAE,wBAAwB;aACtC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,yIAAyI;YAC7I,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAClB,wDAAwD,CAC3D;SACJ;QACD,QAAQ,EAAE;YACN,sBAAsB,EAClB,mHAAmH;SAC1H;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,wDAAwD;CACjE,CAAC,CAAC;AAEP,eAAe,mDAAmD,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-chatmode-file-metadata`. */
|
|
2
3
|
declare const requireChatmodeFileMetadataRule: CopilotRuleModule;
|
|
3
4
|
export default requireChatmodeFileMetadataRule;
|
|
4
5
|
//# sourceMappingURL=require-chatmode-file-metadata.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-chatmode-file-metadata.d.ts","sourceRoot":"","sources":["../../src/rules/require-chatmode-file-metadata.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-chatmode-file-metadata.d.ts","sourceRoot":"","sources":["../../src/rules/require-chatmode-file-metadata.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAmB7E,wDAAwD;AACxD,QAAA,MAAM,+BAA+B,EAAE,iBA4DrC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
import { getCopilotFileKind } from "../_internal/copilot-file-kind.js";
|
|
2
3
|
/**
|
|
3
4
|
* @packageDocumentation
|
|
@@ -6,6 +7,8 @@ import { getCopilotFileKind } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
/** Rule module for `require-chatmode-file-metadata`. */
|
|
9
12
|
const requireChatmodeFileMetadataRule = createCopilotRule({
|
|
10
13
|
create(context) {
|
|
11
14
|
return createMarkdownDocumentListener(() => {
|
|
@@ -20,7 +23,7 @@ const requireChatmodeFileMetadataRule = createCopilotRule({
|
|
|
20
23
|
return;
|
|
21
24
|
}
|
|
22
25
|
const description = getFrontmatterScalar(frontmatter, "description");
|
|
23
|
-
if (description
|
|
26
|
+
if (isDefined(description)) {
|
|
24
27
|
return;
|
|
25
28
|
}
|
|
26
29
|
reportAtDocumentStart(context, {
|
|
@@ -43,6 +46,7 @@ const requireChatmodeFileMetadataRule = createCopilotRule({
|
|
|
43
46
|
frozen: false,
|
|
44
47
|
recommended: true,
|
|
45
48
|
requiresTypeChecking: false,
|
|
49
|
+
url: createRuleDocsUrl("require-chatmode-file-metadata"),
|
|
46
50
|
},
|
|
47
51
|
messages: {
|
|
48
52
|
emptyDescription: "Copilot custom agent and legacy chat mode files must define a non-empty `description` frontmatter value.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-chatmode-file-metadata.js","sourceRoot":"","sources":["../../src/rules/require-chatmode-file-metadata.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-chatmode-file-metadata.js","sourceRoot":"","sources":["../../src/rules/require-chatmode-file-metadata.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAItC,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE;;;GAGG;AACH,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;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,wDAAwD;AACxD,MAAM,+BAA+B,GAAsB,iBAAiB,CAAC;IACzE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,UAAU,EAAE,CAAC;gBACtD,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,oBAAoB;iBAClC,CAAC,CAAC;gBACH,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,oBAAoB,CACpC,WAAW,EACX,aAAa,CAChB,CAAC;YAEF,IAAI,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC;gBACzB,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,SAAS,EAAE,mBAAmB,CAAC,WAAW,EAAE,aAAa,CAAC;oBACtD,CAAC,CAAC,kBAAkB;oBACpB,CAAC,CAAC,oBAAoB;aAC7B,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,yBAAyB;gBACzB,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,kHAAkH;YACtH,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,gCAAgC,CAAC;SAC3D;QACD,QAAQ,EAAE;YACN,gBAAgB,EACZ,0GAA0G;YAC9G,kBAAkB,EACd,gGAAgG;YACpG,kBAAkB,EACd,wHAAwH;SAC/H;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,gCAAgC;CACzC,CAAC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-existing-agent-hook-cwd`. */
|
|
2
3
|
declare const requireExistingAgentHookCwdRule: CopilotRuleModule;
|
|
3
4
|
export default requireExistingAgentHookCwdRule;
|
|
4
5
|
//# sourceMappingURL=require-existing-agent-hook-cwd.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-agent-hook-cwd.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-agent-hook-cwd.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-existing-agent-hook-cwd.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-agent-hook-cwd.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AA0B7E,yDAAyD;AACzD,QAAA,MAAM,+BAA+B,EAAE,iBAmErC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-existing-agent-hook-cwd`.
|
|
@@ -7,6 +8,8 @@ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
|
7
8
|
import { isRelativeWorkspacePath, pathExists, resolveRepositoryRelativePath, } from "../_internal/file-system.js";
|
|
8
9
|
import { extractFrontmatter, getFrontmatterObjectListGroups, } from "../_internal/frontmatter.js";
|
|
9
10
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
11
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
12
|
+
/** Rule module for `require-existing-agent-hook-cwd`. */
|
|
10
13
|
const requireExistingAgentHookCwdRule = createCopilotRule({
|
|
11
14
|
create(context) {
|
|
12
15
|
return createMarkdownDocumentListener(() => {
|
|
@@ -17,7 +20,7 @@ const requireExistingAgentHookCwdRule = createCopilotRule({
|
|
|
17
20
|
const hookGroups = frontmatter === null
|
|
18
21
|
? undefined
|
|
19
22
|
: getFrontmatterObjectListGroups(frontmatter, "hooks");
|
|
20
|
-
if (hookGroups
|
|
23
|
+
if (!isDefined(hookGroups) || hookGroups.size === 0) {
|
|
21
24
|
return;
|
|
22
25
|
}
|
|
23
26
|
const repositoryRoot = findRepositoryRoot(context.filename);
|
|
@@ -29,7 +32,7 @@ const requireExistingAgentHookCwdRule = createCopilotRule({
|
|
|
29
32
|
isRelativeWorkspacePath(cwd) &&
|
|
30
33
|
!pathExists(resolveRepositoryRelativePath(repositoryRoot, cwd)));
|
|
31
34
|
})?.["cwd"];
|
|
32
|
-
if (missingCwd
|
|
35
|
+
if (!isDefined(missingCwd)) {
|
|
33
36
|
continue;
|
|
34
37
|
}
|
|
35
38
|
reportAtDocumentStart(context, {
|
|
@@ -50,6 +53,7 @@ const requireExistingAgentHookCwdRule = createCopilotRule({
|
|
|
50
53
|
frozen: false,
|
|
51
54
|
recommended: false,
|
|
52
55
|
requiresTypeChecking: false,
|
|
56
|
+
url: createRuleDocsUrl("require-existing-agent-hook-cwd"),
|
|
53
57
|
},
|
|
54
58
|
messages: {
|
|
55
59
|
missingAgentHookCwd: "Copilot custom-agent hook `cwd` value `{{cwd}}` does not resolve to an existing repository path.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-agent-hook-cwd.js","sourceRoot":"","sources":["../../src/rules/require-existing-agent-hook-cwd.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-existing-agent-hook-cwd.js","sourceRoot":"","sources":["../../src/rules/require-existing-agent-hook-cwd.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAItC;;;GAGG;AACH,OAAO,EACH,kBAAkB,EAClB,qBAAqB,GACxB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,uBAAuB,EACvB,UAAU,EACV,6BAA6B,GAChC,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,kBAAkB,EAClB,8BAA8B,GACjC,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,yDAAyD;AACzD,MAAM,+BAA+B,GAAsB,iBAAiB,CAAC;IACzE,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;YAChE,MAAM,UAAU,GACZ,WAAW,KAAK,IAAI;gBAChB,CAAC,CAAC,SAAS;gBACX,CAAC,CAAC,8BAA8B,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAE/D,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,UAAU,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;gBAClD,OAAO;YACX,CAAC;YAED,MAAM,cAAc,GAAG,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAE5D,KAAK,MAAM,OAAO,IAAI,UAAU,CAAC,MAAM,EAAE,EAAE,CAAC;gBACxC,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;oBACtC,MAAM,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,CAAC;oBAEjC,OAAO,CACH,OAAO,GAAG,KAAK,QAAQ;wBACvB,GAAG,CAAC,MAAM,GAAG,CAAC;wBACd,uBAAuB,CAAC,GAAG,CAAC;wBAC5B,CAAC,UAAU,CACP,6BAA6B,CAAC,cAAc,EAAE,GAAG,CAAC,CACrD,CACJ,CAAC;gBACN,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;gBAEZ,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC;oBACzB,SAAS;gBACb,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,GAAG,EAAE,UAAU;qBAClB;oBACD,SAAS,EAAE,qBAAqB;iBACnC,CAAC,CAAC;gBAEH,OAAO;YACX,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE,CAAC,wBAAwB,EAAE,qBAAqB,CAAC;YACjE,WAAW,EACP,gGAAgG;YACpG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,iCAAiC,CAAC;SAC5D;QACD,QAAQ,EAAE;YACN,mBAAmB,EACf,kGAAkG;SACzG;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,iCAAiC;CAC1C,CAAC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-existing-agent-mcp-servers`. */
|
|
2
3
|
declare const requireExistingAgentMcpServersRule: CopilotRuleModule;
|
|
3
4
|
export default requireExistingAgentMcpServersRule;
|
|
4
5
|
//# sourceMappingURL=require-existing-agent-mcp-servers.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-agent-mcp-servers.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-agent-mcp-servers.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-existing-agent-mcp-servers.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-agent-mcp-servers.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAyB7E,4DAA4D;AAC5D,QAAA,MAAM,kCAAkC,EAAE,iBAgEzC,CAAC;AAEF,eAAe,kCAAkC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-existing-agent-mcp-servers`.
|
|
@@ -7,6 +8,8 @@ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
|
7
8
|
import { pathExists, resolveRepositoryRelativePath, } from "../_internal/file-system.js";
|
|
8
9
|
import { extractFrontmatter, getFrontmatterList, } from "../_internal/frontmatter.js";
|
|
9
10
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
11
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
12
|
+
/** Rule module for `require-existing-agent-mcp-servers`. */
|
|
10
13
|
const requireExistingAgentMcpServersRule = createCopilotRule({
|
|
11
14
|
create(context) {
|
|
12
15
|
return createMarkdownDocumentListener(() => {
|
|
@@ -17,12 +20,12 @@ const requireExistingAgentMcpServersRule = createCopilotRule({
|
|
|
17
20
|
const mcpServers = frontmatter === null
|
|
18
21
|
? undefined
|
|
19
22
|
: getFrontmatterList(frontmatter, "mcp-servers");
|
|
20
|
-
if (mcpServers
|
|
23
|
+
if (!isDefined(mcpServers)) {
|
|
21
24
|
return;
|
|
22
25
|
}
|
|
23
26
|
const repositoryRoot = findRepositoryRoot(context.filename);
|
|
24
27
|
const missingServer = mcpServers.find((serverPath) => !pathExists(resolveRepositoryRelativePath(repositoryRoot, serverPath)));
|
|
25
|
-
if (missingServer
|
|
28
|
+
if (!isDefined(missingServer)) {
|
|
26
29
|
return;
|
|
27
30
|
}
|
|
28
31
|
reportAtDocumentStart(context, {
|
|
@@ -44,6 +47,7 @@ const requireExistingAgentMcpServersRule = createCopilotRule({
|
|
|
44
47
|
frozen: false,
|
|
45
48
|
recommended: false,
|
|
46
49
|
requiresTypeChecking: false,
|
|
50
|
+
url: createRuleDocsUrl("require-existing-agent-mcp-servers"),
|
|
47
51
|
},
|
|
48
52
|
messages: {
|
|
49
53
|
missingAgentMcpServer: "Copilot custom-agent `mcp-servers` entry `{{mcpServer}}` does not resolve to an existing repository file.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-agent-mcp-servers.js","sourceRoot":"","sources":["../../src/rules/require-existing-agent-mcp-servers.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-existing-agent-mcp-servers.js","sourceRoot":"","sources":["../../src/rules/require-existing-agent-mcp-servers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAItC;;;GAGG;AACH,OAAO,EACH,kBAAkB,EAClB,qBAAqB,GACxB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,UAAU,EACV,6BAA6B,GAChC,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,kBAAkB,EAClB,kBAAkB,GACrB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,4DAA4D;AAC5D,MAAM,kCAAkC,GAAsB,iBAAiB,CAC3E;IACI,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;YAChE,MAAM,UAAU,GACZ,WAAW,KAAK,IAAI;gBAChB,CAAC,CAAC,SAAS;gBACX,CAAC,CAAC,kBAAkB,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;YAEzD,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC;gBACzB,OAAO;YACX,CAAC;YAED,MAAM,cAAc,GAAG,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAC5D,MAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CACjC,CAAC,UAAU,EAAE,EAAE,CACX,CAAC,UAAU,CACP,6BAA6B,CACzB,cAAc,EACd,UAAU,CACb,CACJ,CACR,CAAC;YAEF,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE,CAAC;gBAC5B,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,SAAS,EAAE,aAAa;iBAC3B;gBACD,SAAS,EAAE,uBAAuB;aACrC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,6FAA6F;YACjG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,oCAAoC,CAAC;SAC/D;QACD,QAAQ,EAAE;YACN,qBAAqB,EACjB,2GAA2G;SAClH;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,oCAAoC;CAC7C,CACJ,CAAC;AAEF,eAAe,kCAAkC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-existing-relative-agent-links`. */
|
|
2
3
|
declare const requireExistingRelativeAgentLinksRule: CopilotRuleModule;
|
|
3
4
|
export default requireExistingRelativeAgentLinksRule;
|
|
4
5
|
//# sourceMappingURL=require-existing-relative-agent-links.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-relative-agent-links.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-relative-agent-links.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"require-existing-relative-agent-links.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-relative-agent-links.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAiB7E,+DAA+D;AAC/D,QAAA,MAAM,qCAAqC,EAAE,iBAyEvC,CAAC;AAEP,eAAe,qCAAqC,CAAC"}
|
|
@@ -7,6 +7,8 @@ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
|
7
7
|
import { getCustomizationBodyWithOffset } from "../_internal/customization-body.js";
|
|
8
8
|
import { pathExists } from "../_internal/file-system.js";
|
|
9
9
|
import { extractMarkdownLinks, isRelativeWorkspaceLinkDestination, resolveMarkdownWorkspaceLink, } from "../_internal/markdown-links.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
/** Rule module for `require-existing-relative-agent-links`. */
|
|
10
12
|
const requireExistingRelativeAgentLinksRule = createCopilotRule({
|
|
11
13
|
create(context) {
|
|
12
14
|
return {
|
|
@@ -47,6 +49,7 @@ const requireExistingRelativeAgentLinksRule = createCopilotRule({
|
|
|
47
49
|
frozen: false,
|
|
48
50
|
recommended: false,
|
|
49
51
|
requiresTypeChecking: false,
|
|
52
|
+
url: createRuleDocsUrl("require-existing-relative-agent-links"),
|
|
50
53
|
},
|
|
51
54
|
messages: {
|
|
52
55
|
missingAgentLinkTarget: "Copilot custom-agent relative link `{{destination}}` does not resolve to an existing workspace path.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-relative-agent-links.js","sourceRoot":"","sources":["../../src/rules/require-existing-relative-agent-links.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AACpF,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACH,oBAAoB,EACpB,kCAAkC,EAClC,4BAA4B,GAC/B,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"require-existing-relative-agent-links.js","sourceRoot":"","sources":["../../src/rules/require-existing-relative-agent-links.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AACpF,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACH,oBAAoB,EACpB,kCAAkC,EAClC,4BAA4B,GAC/B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,+DAA+D;AAC/D,MAAM,qCAAqC,GACvC,iBAAiB,CAAC;IACd,MAAM,CAAC,OAAO;QACV,OAAO;YACH,IAAI;gBACA,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC3C,OAAO;gBACX,CAAC;gBAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,8BAA8B,CACnD,OAAO,CAAC,UAAU,CAAC,IAAI,CAC1B,CAAC;gBAEF,KAAK,MAAM,IAAI,IAAI,oBAAoB,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC;oBACpD,IACI,CAAC,kCAAkC,CAC/B,IAAI,CAAC,WAAW,CACnB,EACH,CAAC;wBACC,SAAS;oBACb,CAAC;oBAED,IACI,UAAU,CACN,4BAA4B,CACxB,OAAO,CAAC,QAAQ,EAChB,IAAI,CAAC,WAAW,CACnB,CACJ,EACH,CAAC;wBACC,SAAS;oBACb,CAAC;oBAED,OAAO,CAAC,MAAM,CAAC;wBACX,IAAI,EAAE;4BACF,WAAW,EAAE,IAAI,CAAC,WAAW;yBAChC;wBACD,GAAG,EAAE;4BACD,GAAG,EAAE,OAAO,CAAC,UAAU,CAAC,eAAe,CACnC,IAAI,CAAC,GAAG,CACX;4BACD,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,eAAe,CACrC,IAAI,CAAC,KAAK,CACb;yBACJ;wBACD,SAAS,EAAE,wBAAwB;qBACtC,CAAC,CAAC;gBACP,CAAC;YACL,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,oGAAoG;YACxG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,uCAAuC,CAAC;SAClE;QACD,QAAQ,EAAE;YACN,sBAAsB,EAClB,sGAAsG;SAC7G;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,uCAAuC;CAChD,CAAC,CAAC;AAEP,eAAe,qCAAqC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-existing-relative-instructions-links`. */
|
|
2
3
|
declare const requireExistingRelativeInstructionsLinksRule: CopilotRuleModule;
|
|
3
4
|
export default requireExistingRelativeInstructionsLinksRule;
|
|
4
5
|
//# sourceMappingURL=require-existing-relative-instructions-links.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-relative-instructions-links.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-relative-instructions-links.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"require-existing-relative-instructions-links.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-relative-instructions-links.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAiB7E,sEAAsE;AACtE,QAAA,MAAM,4CAA4C,EAAE,iBA6E9C,CAAC;AAEP,eAAe,4CAA4C,CAAC"}
|
|
@@ -7,6 +7,8 @@ import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
|
7
7
|
import { getCustomizationBodyWithOffset } from "../_internal/customization-body.js";
|
|
8
8
|
import { pathExists } from "../_internal/file-system.js";
|
|
9
9
|
import { extractMarkdownLinks, isRelativeWorkspaceLinkDestination, resolveMarkdownWorkspaceLink, } from "../_internal/markdown-links.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
/** Rule module for `require-existing-relative-instructions-links`. */
|
|
10
12
|
const requireExistingRelativeInstructionsLinksRule = createCopilotRule({
|
|
11
13
|
create(context) {
|
|
12
14
|
return {
|
|
@@ -47,6 +49,7 @@ const requireExistingRelativeInstructionsLinksRule = createCopilotRule({
|
|
|
47
49
|
frozen: false,
|
|
48
50
|
recommended: false,
|
|
49
51
|
requiresTypeChecking: false,
|
|
52
|
+
url: createRuleDocsUrl("require-existing-relative-instructions-links"),
|
|
50
53
|
},
|
|
51
54
|
messages: {
|
|
52
55
|
missingInstructionsLinkTarget: "Copilot instructions relative link `{{destination}}` does not resolve to an existing workspace path.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-relative-instructions-links.js","sourceRoot":"","sources":["../../src/rules/require-existing-relative-instructions-links.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AACpF,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACH,oBAAoB,EACpB,kCAAkC,EAClC,4BAA4B,GAC/B,MAAM,gCAAgC,CAAC;
|
|
1
|
+
{"version":3,"file":"require-existing-relative-instructions-links.js","sourceRoot":"","sources":["../../src/rules/require-existing-relative-instructions-links.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AACpF,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EACH,oBAAoB,EACpB,kCAAkC,EAClC,4BAA4B,GAC/B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,sEAAsE;AACtE,MAAM,4CAA4C,GAC9C,iBAAiB,CAAC;IACd,MAAM,CAAC,OAAO;QACV,OAAO;YACH,IAAI;gBACA,IACI,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,cAAc,EACzD,CAAC;oBACC,OAAO;gBACX,CAAC;gBAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,8BAA8B,CACnD,OAAO,CAAC,UAAU,CAAC,IAAI,CAC1B,CAAC;gBAEF,KAAK,MAAM,IAAI,IAAI,oBAAoB,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC;oBACpD,IACI,CAAC,kCAAkC,CAC/B,IAAI,CAAC,WAAW,CACnB,EACH,CAAC;wBACC,SAAS;oBACb,CAAC;oBAED,IACI,UAAU,CACN,4BAA4B,CACxB,OAAO,CAAC,QAAQ,EAChB,IAAI,CAAC,WAAW,CACnB,CACJ,EACH,CAAC;wBACC,SAAS;oBACb,CAAC;oBAED,OAAO,CAAC,MAAM,CAAC;wBACX,IAAI,EAAE;4BACF,WAAW,EAAE,IAAI,CAAC,WAAW;yBAChC;wBACD,GAAG,EAAE;4BACD,GAAG,EAAE,OAAO,CAAC,UAAU,CAAC,eAAe,CACnC,IAAI,CAAC,GAAG,CACX;4BACD,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,eAAe,CACrC,IAAI,CAAC,KAAK,CACb;yBACJ;wBACD,SAAS,EAAE,+BAA+B;qBAC7C,CAAC,CAAC;gBACP,CAAC;YACL,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,uHAAuH;YAC3H,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAClB,8CAA8C,CACjD;SACJ;QACD,QAAQ,EAAE;YACN,6BAA6B,EACzB,sGAAsG;SAC7G;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,8CAA8C;CACvD,CAAC,CAAC;AAEP,eAAe,4CAA4C,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-existing-relative-prompt-links`. */
|
|
2
3
|
declare const requireExistingRelativePromptLinksRule: CopilotRuleModule;
|
|
3
4
|
export default requireExistingRelativePromptLinksRule;
|
|
4
5
|
//# sourceMappingURL=require-existing-relative-prompt-links.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-existing-relative-prompt-links.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-relative-prompt-links.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;
|
|
1
|
+
{"version":3,"file":"require-existing-relative-prompt-links.d.ts","sourceRoot":"","sources":["../../src/rules/require-existing-relative-prompt-links.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAiB7E,gEAAgE;AAChE,QAAA,MAAM,sCAAsC,EAAE,iBA2ExC,CAAC;AAEP,eAAe,sCAAsC,CAAC"}
|