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.
- package/CHANGELOG.md +5316 -0
- package/LICENSE +21 -0
- package/README.md +192 -0
- package/dist/_internal/copilot-config-references.d.ts +34 -0
- package/dist/_internal/copilot-config-references.d.ts.map +1 -0
- package/dist/_internal/copilot-config-references.js +55 -0
- package/dist/_internal/copilot-config-references.js.map +1 -0
- package/dist/_internal/copilot-customization-names.d.ts +21 -0
- package/dist/_internal/copilot-customization-names.d.ts.map +1 -0
- package/dist/_internal/copilot-customization-names.js +56 -0
- package/dist/_internal/copilot-customization-names.js.map +1 -0
- package/dist/_internal/copilot-file-kind.d.ts +19 -0
- package/dist/_internal/copilot-file-kind.d.ts.map +1 -0
- package/dist/_internal/copilot-file-kind.js +111 -0
- package/dist/_internal/copilot-file-kind.js.map +1 -0
- package/dist/_internal/create-copilot-rule.d.ts +39 -0
- package/dist/_internal/create-copilot-rule.d.ts.map +1 -0
- package/dist/_internal/create-copilot-rule.js +56 -0
- package/dist/_internal/create-copilot-rule.js.map +1 -0
- package/dist/_internal/customization-body.d.ts +6 -0
- package/dist/_internal/customization-body.d.ts.map +1 -0
- package/dist/_internal/customization-body.js +15 -0
- package/dist/_internal/customization-body.js.map +1 -0
- package/dist/_internal/duplicate-names.d.ts +12 -0
- package/dist/_internal/duplicate-names.d.ts.map +1 -0
- package/dist/_internal/duplicate-names.js +24 -0
- package/dist/_internal/duplicate-names.js.map +1 -0
- package/dist/_internal/file-system.d.ts +21 -0
- package/dist/_internal/file-system.d.ts.map +1 -0
- package/dist/_internal/file-system.js +86 -0
- package/dist/_internal/file-system.js.map +1 -0
- package/dist/_internal/frontmatter.d.ts +37 -0
- package/dist/_internal/frontmatter.d.ts.map +1 -0
- package/dist/_internal/frontmatter.js +398 -0
- package/dist/_internal/frontmatter.js.map +1 -0
- package/dist/_internal/markdown-links.d.ts +21 -0
- package/dist/_internal/markdown-links.d.ts.map +1 -0
- package/dist/_internal/markdown-links.js +81 -0
- package/dist/_internal/markdown-links.js.map +1 -0
- package/dist/_internal/markdown-rule.d.ts +13 -0
- package/dist/_internal/markdown-rule.d.ts.map +1 -0
- package/dist/_internal/markdown-rule.js +19 -0
- package/dist/_internal/markdown-rule.js.map +1 -0
- package/dist/_internal/repository-hooks-json.d.ts +55 -0
- package/dist/_internal/repository-hooks-json.d.ts.map +1 -0
- package/dist/_internal/repository-hooks-json.js +80 -0
- package/dist/_internal/repository-hooks-json.js.map +1 -0
- package/dist/_internal/rule-catalog.d.ts +20 -0
- package/dist/_internal/rule-catalog.d.ts.map +1 -0
- package/dist/_internal/rule-catalog.js +97 -0
- package/dist/_internal/rule-catalog.js.map +1 -0
- package/dist/_internal/rule-docs-url.d.ts +9 -0
- package/dist/_internal/rule-docs-url.d.ts.map +1 -0
- package/dist/_internal/rule-docs-url.js +9 -0
- package/dist/_internal/rule-docs-url.js.map +1 -0
- package/dist/_internal/rules-registry.d.ts +83 -0
- package/dist/_internal/rules-registry.d.ts.map +1 -0
- package/dist/_internal/rules-registry.js +145 -0
- package/dist/_internal/rules-registry.js.map +1 -0
- package/dist/_internal/skill-files.d.ts +8 -0
- package/dist/_internal/skill-files.d.ts.map +1 -0
- package/dist/_internal/skill-files.js +18 -0
- package/dist/_internal/skill-files.js.map +1 -0
- package/dist/plugin.cjs +5312 -0
- package/dist/plugin.cjs.map +7 -0
- package/dist/plugin.d.cts +34 -0
- package/dist/plugin.d.ts +34 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +142 -0
- package/dist/plugin.js.map +1 -0
- package/dist/rules/no-blank-customization-body.d.ts +4 -0
- package/dist/rules/no-blank-customization-body.d.ts.map +1 -0
- package/dist/rules/no-blank-customization-body.js +49 -0
- package/dist/rules/no-blank-customization-body.js.map +1 -0
- package/dist/rules/no-blank-repository-instructions.d.ts +4 -0
- package/dist/rules/no-blank-repository-instructions.d.ts.map +1 -0
- package/dist/rules/no-blank-repository-instructions.js +49 -0
- package/dist/rules/no-blank-repository-instructions.js.map +1 -0
- package/dist/rules/no-blank-skill-body.d.ts +4 -0
- package/dist/rules/no-blank-skill-body.d.ts.map +1 -0
- package/dist/rules/no-blank-skill-body.js +48 -0
- package/dist/rules/no-blank-skill-body.js.map +1 -0
- package/dist/rules/no-deprecated-agent-infer.d.ts +4 -0
- package/dist/rules/no-deprecated-agent-infer.d.ts.map +1 -0
- package/dist/rules/no-deprecated-agent-infer.js +48 -0
- package/dist/rules/no-deprecated-agent-infer.js.map +1 -0
- package/dist/rules/no-duplicate-agent-names.d.ts +4 -0
- package/dist/rules/no-duplicate-agent-names.d.ts.map +1 -0
- package/dist/rules/no-duplicate-agent-names.js +72 -0
- package/dist/rules/no-duplicate-agent-names.js.map +1 -0
- package/dist/rules/no-duplicate-prompt-names.d.ts +4 -0
- package/dist/rules/no-duplicate-prompt-names.d.ts.map +1 -0
- package/dist/rules/no-duplicate-prompt-names.js +72 -0
- package/dist/rules/no-duplicate-prompt-names.js.map +1 -0
- package/dist/rules/no-duplicate-skill-names.d.ts +4 -0
- package/dist/rules/no-duplicate-skill-names.d.ts.map +1 -0
- package/dist/rules/no-duplicate-skill-names.js +74 -0
- package/dist/rules/no-duplicate-skill-names.js.map +1 -0
- package/dist/rules/no-duplicate-slash-command-names.d.ts +4 -0
- package/dist/rules/no-duplicate-slash-command-names.d.ts.map +1 -0
- package/dist/rules/no-duplicate-slash-command-names.js +82 -0
- package/dist/rules/no-duplicate-slash-command-names.js.map +1 -0
- package/dist/rules/no-empty-repository-hook-arrays.d.ts +4 -0
- package/dist/rules/no-empty-repository-hook-arrays.d.ts.map +1 -0
- package/dist/rules/no-empty-repository-hook-arrays.js +49 -0
- package/dist/rules/no-empty-repository-hook-arrays.js.map +1 -0
- package/dist/rules/no-legacy-chatmode-files.d.ts +4 -0
- package/dist/rules/no-legacy-chatmode-files.d.ts.map +1 -0
- package/dist/rules/no-legacy-chatmode-files.js +42 -0
- package/dist/rules/no-legacy-chatmode-files.js.map +1 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts +4 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts.map +1 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.js +52 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.js.map +1 -0
- package/dist/rules/prefer-fast-repository-hooks.d.ts +4 -0
- package/dist/rules/prefer-fast-repository-hooks.d.ts.map +1 -0
- package/dist/rules/prefer-fast-repository-hooks.js +58 -0
- package/dist/rules/prefer-fast-repository-hooks.js.map +1 -0
- package/dist/rules/prefer-qualified-tools.d.ts +4 -0
- package/dist/rules/prefer-qualified-tools.d.ts.map +1 -0
- package/dist/rules/prefer-qualified-tools.js +56 -0
- package/dist/rules/prefer-qualified-tools.js.map +1 -0
- package/dist/rules/require-agent-tool-for-subagents.d.ts +4 -0
- package/dist/rules/require-agent-tool-for-subagents.d.ts.map +1 -0
- package/dist/rules/require-agent-tool-for-subagents.js +64 -0
- package/dist/rules/require-agent-tool-for-subagents.js.map +1 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts +4 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts.map +1 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js +50 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js.map +1 -0
- package/dist/rules/require-chatmode-file-metadata.d.ts +4 -0
- package/dist/rules/require-chatmode-file-metadata.d.ts.map +1 -0
- package/dist/rules/require-chatmode-file-metadata.js +59 -0
- package/dist/rules/require-chatmode-file-metadata.js.map +1 -0
- package/dist/rules/require-existing-agent-hook-cwd.d.ts +4 -0
- package/dist/rules/require-existing-agent-hook-cwd.d.ts.map +1 -0
- package/dist/rules/require-existing-agent-hook-cwd.js +64 -0
- package/dist/rules/require-existing-agent-hook-cwd.js.map +1 -0
- package/dist/rules/require-existing-agent-mcp-servers.d.ts +4 -0
- package/dist/rules/require-existing-agent-mcp-servers.d.ts.map +1 -0
- package/dist/rules/require-existing-agent-mcp-servers.js +58 -0
- package/dist/rules/require-existing-agent-mcp-servers.js.map +1 -0
- package/dist/rules/require-existing-relative-agent-links.d.ts +4 -0
- package/dist/rules/require-existing-relative-agent-links.d.ts.map +1 -0
- package/dist/rules/require-existing-relative-agent-links.js +61 -0
- package/dist/rules/require-existing-relative-agent-links.js.map +1 -0
- package/dist/rules/require-existing-relative-instructions-links.d.ts +4 -0
- package/dist/rules/require-existing-relative-instructions-links.d.ts.map +1 -0
- package/dist/rules/require-existing-relative-instructions-links.js +61 -0
- package/dist/rules/require-existing-relative-instructions-links.js.map +1 -0
- package/dist/rules/require-existing-relative-prompt-links.d.ts +4 -0
- package/dist/rules/require-existing-relative-prompt-links.d.ts.map +1 -0
- package/dist/rules/require-existing-relative-prompt-links.js +61 -0
- package/dist/rules/require-existing-relative-prompt-links.js.map +1 -0
- package/dist/rules/require-existing-relative-skill-links.d.ts +4 -0
- package/dist/rules/require-existing-relative-skill-links.d.ts.map +1 -0
- package/dist/rules/require-existing-relative-skill-links.js +61 -0
- package/dist/rules/require-existing-relative-skill-links.js.map +1 -0
- package/dist/rules/require-existing-repository-hook-cwd.d.ts +4 -0
- package/dist/rules/require-existing-repository-hook-cwd.d.ts.map +1 -0
- package/dist/rules/require-existing-repository-hook-cwd.js +65 -0
- package/dist/rules/require-existing-repository-hook-cwd.js.map +1 -0
- package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts +4 -0
- package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts.map +1 -0
- package/dist/rules/require-github-copilot-target-for-mcp-servers.js +63 -0
- package/dist/rules/require-github-copilot-target-for-mcp-servers.js.map +1 -0
- package/dist/rules/require-instructions-apply-to.d.ts +4 -0
- package/dist/rules/require-instructions-apply-to.d.ts.map +1 -0
- package/dist/rules/require-instructions-apply-to.js +60 -0
- package/dist/rules/require-instructions-apply-to.js.map +1 -0
- package/dist/rules/require-json-agent-mcp-servers.d.ts +4 -0
- package/dist/rules/require-json-agent-mcp-servers.d.ts.map +1 -0
- package/dist/rules/require-json-agent-mcp-servers.js +58 -0
- package/dist/rules/require-json-agent-mcp-servers.js.map +1 -0
- package/dist/rules/require-prompt-file-metadata.d.ts +4 -0
- package/dist/rules/require-prompt-file-metadata.d.ts.map +1 -0
- package/dist/rules/require-prompt-file-metadata.js +104 -0
- package/dist/rules/require-prompt-file-metadata.js.map +1 -0
- package/dist/rules/require-qualified-agent-handoff-models.d.ts +4 -0
- package/dist/rules/require-qualified-agent-handoff-models.d.ts.map +1 -0
- package/dist/rules/require-qualified-agent-handoff-models.js +78 -0
- package/dist/rules/require-qualified-agent-handoff-models.js.map +1 -0
- package/dist/rules/require-relative-agent-hook-cwd.d.ts +4 -0
- package/dist/rules/require-relative-agent-hook-cwd.d.ts.map +1 -0
- package/dist/rules/require-relative-agent-hook-cwd.js +70 -0
- package/dist/rules/require-relative-agent-hook-cwd.js.map +1 -0
- package/dist/rules/require-relative-agent-links.d.ts +4 -0
- package/dist/rules/require-relative-agent-links.d.ts.map +1 -0
- package/dist/rules/require-relative-agent-links.js +58 -0
- package/dist/rules/require-relative-agent-links.js.map +1 -0
- package/dist/rules/require-relative-instructions-links.d.ts +4 -0
- package/dist/rules/require-relative-instructions-links.d.ts.map +1 -0
- package/dist/rules/require-relative-instructions-links.js +58 -0
- package/dist/rules/require-relative-instructions-links.js.map +1 -0
- package/dist/rules/require-relative-prompt-links.d.ts +4 -0
- package/dist/rules/require-relative-prompt-links.d.ts.map +1 -0
- package/dist/rules/require-relative-prompt-links.js +82 -0
- package/dist/rules/require-relative-prompt-links.js.map +1 -0
- package/dist/rules/require-relative-repository-hook-cwd.d.ts +4 -0
- package/dist/rules/require-relative-repository-hook-cwd.d.ts.map +1 -0
- package/dist/rules/require-relative-repository-hook-cwd.js +63 -0
- package/dist/rules/require-relative-repository-hook-cwd.js.map +1 -0
- package/dist/rules/require-relative-skill-links.d.ts +4 -0
- package/dist/rules/require-relative-skill-links.d.ts.map +1 -0
- package/dist/rules/require-relative-skill-links.js +58 -0
- package/dist/rules/require-relative-skill-links.js.map +1 -0
- package/dist/rules/require-repository-hook-arrays.d.ts +4 -0
- package/dist/rules/require-repository-hook-arrays.d.ts.map +1 -0
- package/dist/rules/require-repository-hook-arrays.js +54 -0
- package/dist/rules/require-repository-hook-arrays.js.map +1 -0
- package/dist/rules/require-repository-hook-command-shell.d.ts +4 -0
- package/dist/rules/require-repository-hook-command-shell.d.ts.map +1 -0
- package/dist/rules/require-repository-hook-command-shell.js +57 -0
- package/dist/rules/require-repository-hook-command-shell.js.map +1 -0
- package/dist/rules/require-repository-hooks-object.d.ts +4 -0
- package/dist/rules/require-repository-hooks-object.d.ts.map +1 -0
- package/dist/rules/require-repository-hooks-object.js +50 -0
- package/dist/rules/require-repository-hooks-object.js.map +1 -0
- package/dist/rules/require-repository-instructions-file.d.ts +4 -0
- package/dist/rules/require-repository-instructions-file.d.ts.map +1 -0
- package/dist/rules/require-repository-instructions-file.js +50 -0
- package/dist/rules/require-repository-instructions-file.js.map +1 -0
- package/dist/rules/require-skill-file-location.d.ts +4 -0
- package/dist/rules/require-skill-file-location.d.ts.map +1 -0
- package/dist/rules/require-skill-file-location.js +46 -0
- package/dist/rules/require-skill-file-location.js.map +1 -0
- package/dist/rules/require-skill-file-metadata.d.ts +4 -0
- package/dist/rules/require-skill-file-metadata.d.ts.map +1 -0
- package/dist/rules/require-skill-file-metadata.js +60 -0
- package/dist/rules/require-skill-file-metadata.js.map +1 -0
- package/dist/rules/require-skill-md-filename.d.ts +4 -0
- package/dist/rules/require-skill-md-filename.d.ts.map +1 -0
- package/dist/rules/require-skill-md-filename.js +55 -0
- package/dist/rules/require-skill-md-filename.js.map +1 -0
- package/dist/rules/require-skill-name-match-directory.d.ts +4 -0
- package/dist/rules/require-skill-name-match-directory.d.ts.map +1 -0
- package/dist/rules/require-skill-name-match-directory.js +59 -0
- package/dist/rules/require-skill-name-match-directory.js.map +1 -0
- package/dist/rules/require-string-repository-hook-env-values.d.ts +4 -0
- package/dist/rules/require-string-repository-hook-env-values.d.ts.map +1 -0
- package/dist/rules/require-string-repository-hook-env-values.js +59 -0
- package/dist/rules/require-string-repository-hook-env-values.js.map +1 -0
- package/dist/rules/require-valid-agent-argument-hint.d.ts +4 -0
- package/dist/rules/require-valid-agent-argument-hint.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-argument-hint.js +51 -0
- package/dist/rules/require-valid-agent-argument-hint.js.map +1 -0
- package/dist/rules/require-valid-agent-handoff-send.d.ts +4 -0
- package/dist/rules/require-valid-agent-handoff-send.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-handoff-send.js +67 -0
- package/dist/rules/require-valid-agent-handoff-send.js.map +1 -0
- package/dist/rules/require-valid-agent-handoffs.d.ts +4 -0
- package/dist/rules/require-valid-agent-handoffs.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-handoffs.js +78 -0
- package/dist/rules/require-valid-agent-handoffs.js.map +1 -0
- package/dist/rules/require-valid-agent-hook-events.d.ts +4 -0
- package/dist/rules/require-valid-agent-hook-events.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-hook-events.js +68 -0
- package/dist/rules/require-valid-agent-hook-events.js.map +1 -0
- package/dist/rules/require-valid-agent-hook-timeouts.d.ts +4 -0
- package/dist/rules/require-valid-agent-hook-timeouts.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-hook-timeouts.js +83 -0
- package/dist/rules/require-valid-agent-hook-timeouts.js.map +1 -0
- package/dist/rules/require-valid-agent-hooks.d.ts +4 -0
- package/dist/rules/require-valid-agent-hooks.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-hooks.js +86 -0
- package/dist/rules/require-valid-agent-hooks.js.map +1 -0
- package/dist/rules/require-valid-agent-invocation-controls.d.ts +4 -0
- package/dist/rules/require-valid-agent-invocation-controls.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-invocation-controls.js +71 -0
- package/dist/rules/require-valid-agent-invocation-controls.js.map +1 -0
- package/dist/rules/require-valid-agent-mcp-servers.d.ts +4 -0
- package/dist/rules/require-valid-agent-mcp-servers.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-mcp-servers.js +64 -0
- package/dist/rules/require-valid-agent-mcp-servers.js.map +1 -0
- package/dist/rules/require-valid-agent-model.d.ts +4 -0
- package/dist/rules/require-valid-agent-model.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-model.js +64 -0
- package/dist/rules/require-valid-agent-model.js.map +1 -0
- package/dist/rules/require-valid-agent-name.d.ts +4 -0
- package/dist/rules/require-valid-agent-name.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-name.js +51 -0
- package/dist/rules/require-valid-agent-name.js.map +1 -0
- package/dist/rules/require-valid-agent-subagents.d.ts +4 -0
- package/dist/rules/require-valid-agent-subagents.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-subagents.js +79 -0
- package/dist/rules/require-valid-agent-subagents.js.map +1 -0
- package/dist/rules/require-valid-agent-target.d.ts +4 -0
- package/dist/rules/require-valid-agent-target.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-target.js +62 -0
- package/dist/rules/require-valid-agent-target.js.map +1 -0
- package/dist/rules/require-valid-agent-tools.d.ts +4 -0
- package/dist/rules/require-valid-agent-tools.d.ts.map +1 -0
- package/dist/rules/require-valid-agent-tools.js +64 -0
- package/dist/rules/require-valid-agent-tools.js.map +1 -0
- package/dist/rules/require-valid-instructions-apply-to-globs.d.ts +4 -0
- package/dist/rules/require-valid-instructions-apply-to-globs.d.ts.map +1 -0
- package/dist/rules/require-valid-instructions-apply-to-globs.js +79 -0
- package/dist/rules/require-valid-instructions-apply-to-globs.js.map +1 -0
- package/dist/rules/require-valid-prompt-argument-hint.d.ts +4 -0
- package/dist/rules/require-valid-prompt-argument-hint.d.ts.map +1 -0
- package/dist/rules/require-valid-prompt-argument-hint.js +52 -0
- package/dist/rules/require-valid-prompt-argument-hint.js.map +1 -0
- package/dist/rules/require-valid-prompt-model.d.ts +4 -0
- package/dist/rules/require-valid-prompt-model.d.ts.map +1 -0
- package/dist/rules/require-valid-prompt-model.js +77 -0
- package/dist/rules/require-valid-prompt-model.js.map +1 -0
- package/dist/rules/require-valid-prompt-name.d.ts +4 -0
- package/dist/rules/require-valid-prompt-name.d.ts.map +1 -0
- package/dist/rules/require-valid-prompt-name.js +51 -0
- package/dist/rules/require-valid-prompt-name.js.map +1 -0
- package/dist/rules/require-valid-prompt-tools.d.ts +4 -0
- package/dist/rules/require-valid-prompt-tools.d.ts.map +1 -0
- package/dist/rules/require-valid-prompt-tools.js +64 -0
- package/dist/rules/require-valid-prompt-tools.js.map +1 -0
- package/dist/rules/require-valid-repository-hook-command-type.d.ts +4 -0
- package/dist/rules/require-valid-repository-hook-command-type.d.ts.map +1 -0
- package/dist/rules/require-valid-repository-hook-command-type.js +58 -0
- package/dist/rules/require-valid-repository-hook-command-type.js.map +1 -0
- package/dist/rules/require-valid-repository-hook-env.d.ts +4 -0
- package/dist/rules/require-valid-repository-hook-env.d.ts.map +1 -0
- package/dist/rules/require-valid-repository-hook-env.js +57 -0
- package/dist/rules/require-valid-repository-hook-env.js.map +1 -0
- package/dist/rules/require-valid-repository-hook-events.d.ts +4 -0
- package/dist/rules/require-valid-repository-hook-events.d.ts.map +1 -0
- package/dist/rules/require-valid-repository-hook-events.js +55 -0
- package/dist/rules/require-valid-repository-hook-events.js.map +1 -0
- package/dist/rules/require-valid-repository-hook-timeouts.d.ts +4 -0
- package/dist/rules/require-valid-repository-hook-timeouts.d.ts.map +1 -0
- package/dist/rules/require-valid-repository-hook-timeouts.js +59 -0
- package/dist/rules/require-valid-repository-hook-timeouts.js.map +1 -0
- package/dist/rules/require-valid-repository-hook-version.d.ts +4 -0
- package/dist/rules/require-valid-repository-hook-version.d.ts.map +1 -0
- package/dist/rules/require-valid-repository-hook-version.js +53 -0
- package/dist/rules/require-valid-repository-hook-version.js.map +1 -0
- package/dist/rules/require-valid-skill-directory-name.d.ts +4 -0
- package/dist/rules/require-valid-skill-directory-name.d.ts.map +1 -0
- package/dist/rules/require-valid-skill-directory-name.js +50 -0
- package/dist/rules/require-valid-skill-directory-name.js.map +1 -0
- package/dist/rules/require-valid-skill-license.d.ts +4 -0
- package/dist/rules/require-valid-skill-license.d.ts.map +1 -0
- package/dist/rules/require-valid-skill-license.js +47 -0
- package/dist/rules/require-valid-skill-license.js.map +1 -0
- package/dist/rules/require-valid-skill-name.d.ts +4 -0
- package/dist/rules/require-valid-skill-name.d.ts.map +1 -0
- package/dist/rules/require-valid-skill-name.js +57 -0
- package/dist/rules/require-valid-skill-name.js.map +1 -0
- package/docs/rules/getting-started.md +24 -0
- package/docs/rules/guides/copilot-customization-files.md +17 -0
- package/docs/rules/no-blank-customization-body.md +52 -0
- package/docs/rules/no-blank-repository-instructions.md +37 -0
- package/docs/rules/no-blank-skill-body.md +41 -0
- package/docs/rules/no-deprecated-agent-infer.md +42 -0
- package/docs/rules/no-duplicate-agent-names.md +36 -0
- package/docs/rules/no-duplicate-prompt-names.md +36 -0
- package/docs/rules/no-duplicate-skill-names.md +37 -0
- package/docs/rules/no-duplicate-slash-command-names.md +40 -0
- package/docs/rules/no-empty-repository-hook-arrays.md +44 -0
- package/docs/rules/no-legacy-chatmode-files.md +53 -0
- package/docs/rules/overview.md +27 -0
- package/docs/rules/prefer-custom-instructions-under-code-review-limit.md +39 -0
- package/docs/rules/prefer-fast-repository-hooks.md +43 -0
- package/docs/rules/prefer-qualified-tools.md +49 -0
- package/docs/rules/presets/all.md +82 -0
- package/docs/rules/presets/index.md +78 -0
- package/docs/rules/presets/minimal.md +16 -0
- package/docs/rules/presets/recommended.md +67 -0
- package/docs/rules/presets/strict.md +81 -0
- package/docs/rules/require-agent-tool-for-subagents.md +44 -0
- package/docs/rules/require-agents-md-for-cross-surface-agent-instructions.md +39 -0
- package/docs/rules/require-chatmode-file-metadata.md +41 -0
- package/docs/rules/require-existing-agent-hook-cwd.md +51 -0
- package/docs/rules/require-existing-agent-mcp-servers.md +43 -0
- package/docs/rules/require-existing-relative-agent-links.md +41 -0
- package/docs/rules/require-existing-relative-instructions-links.md +43 -0
- package/docs/rules/require-existing-relative-prompt-links.md +41 -0
- package/docs/rules/require-existing-relative-skill-links.md +44 -0
- package/docs/rules/require-existing-repository-hook-cwd.md +45 -0
- package/docs/rules/require-github-copilot-target-for-mcp-servers.md +46 -0
- package/docs/rules/require-instructions-apply-to.md +40 -0
- package/docs/rules/require-json-agent-mcp-servers.md +41 -0
- package/docs/rules/require-prompt-file-metadata.md +45 -0
- package/docs/rules/require-qualified-agent-handoff-models.md +47 -0
- package/docs/rules/require-relative-agent-hook-cwd.md +50 -0
- package/docs/rules/require-relative-agent-links.md +40 -0
- package/docs/rules/require-relative-instructions-links.md +42 -0
- package/docs/rules/require-relative-prompt-links.md +43 -0
- package/docs/rules/require-relative-repository-hook-cwd.md +43 -0
- package/docs/rules/require-relative-skill-links.md +42 -0
- package/docs/rules/require-repository-hook-arrays.md +33 -0
- package/docs/rules/require-repository-hook-command-shell.md +44 -0
- package/docs/rules/require-repository-hooks-object.md +34 -0
- package/docs/rules/require-repository-instructions-file.md +42 -0
- package/docs/rules/require-skill-file-location.md +33 -0
- package/docs/rules/require-skill-file-metadata.md +40 -0
- package/docs/rules/require-skill-md-filename.md +43 -0
- package/docs/rules/require-skill-name-match-directory.md +46 -0
- package/docs/rules/require-string-repository-hook-env-values.md +43 -0
- package/docs/rules/require-valid-agent-argument-hint.md +42 -0
- package/docs/rules/require-valid-agent-handoff-send.md +49 -0
- package/docs/rules/require-valid-agent-handoffs.md +51 -0
- package/docs/rules/require-valid-agent-hook-events.md +47 -0
- package/docs/rules/require-valid-agent-hook-timeouts.md +49 -0
- package/docs/rules/require-valid-agent-hooks.md +49 -0
- package/docs/rules/require-valid-agent-invocation-controls.md +45 -0
- package/docs/rules/require-valid-agent-mcp-servers.md +45 -0
- package/docs/rules/require-valid-agent-model.md +43 -0
- package/docs/rules/require-valid-agent-name.md +42 -0
- package/docs/rules/require-valid-agent-subagents.md +52 -0
- package/docs/rules/require-valid-agent-target.md +44 -0
- package/docs/rules/require-valid-agent-tools.md +43 -0
- package/docs/rules/require-valid-instructions-apply-to-globs.md +45 -0
- package/docs/rules/require-valid-prompt-argument-hint.md +42 -0
- package/docs/rules/require-valid-prompt-model.md +45 -0
- package/docs/rules/require-valid-prompt-name.md +42 -0
- package/docs/rules/require-valid-prompt-tools.md +43 -0
- package/docs/rules/require-valid-repository-hook-command-type.md +45 -0
- package/docs/rules/require-valid-repository-hook-env.md +43 -0
- package/docs/rules/require-valid-repository-hook-events.md +34 -0
- package/docs/rules/require-valid-repository-hook-timeouts.md +43 -0
- package/docs/rules/require-valid-repository-hook-version.md +34 -0
- package/docs/rules/require-valid-skill-directory-name.md +34 -0
- package/docs/rules/require-valid-skill-license.md +45 -0
- package/docs/rules/require-valid-skill-name.md +43 -0
- package/package.json +562 -0
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import * as fs from "node:fs";
|
|
2
|
+
/**
|
|
3
|
+
* @packageDocumentation
|
|
4
|
+
* ESLint rule implementation for `no-duplicate-prompt-names`.
|
|
5
|
+
*/
|
|
6
|
+
import * as path from "node:path";
|
|
7
|
+
import { getPromptName, normalizeNameForComparison, } from "../_internal/copilot-customization-names.js";
|
|
8
|
+
import { findRepositoryRoot } from "../_internal/copilot-file-kind.js";
|
|
9
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
10
|
+
import { collectDuplicateNameGroups } from "../_internal/duplicate-names.js";
|
|
11
|
+
import { listFilesRecursively } from "../_internal/file-system.js";
|
|
12
|
+
import { extractFrontmatter } from "../_internal/frontmatter.js";
|
|
13
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
14
|
+
const normalizeRelativeFilePath = (repositoryRoot, filePath) => path.relative(repositoryRoot, filePath).replaceAll("\\", "/");
|
|
15
|
+
const noDuplicatePromptNamesRule = createCopilotRule({
|
|
16
|
+
create(context) {
|
|
17
|
+
return createMarkdownDocumentListener(() => {
|
|
18
|
+
if (!context.filename.endsWith(".prompt.md")) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const repositoryRoot = findRepositoryRoot(context.filename);
|
|
22
|
+
const promptDirectory = path.join(repositoryRoot, ".github", "prompts");
|
|
23
|
+
const promptFiles = listFilesRecursively(promptDirectory, (filePath) => filePath.endsWith(".prompt.md"));
|
|
24
|
+
const duplicateGroups = collectDuplicateNameGroups(promptFiles.map((filePath) => {
|
|
25
|
+
const sourceText = context.filename === filePath
|
|
26
|
+
? context.sourceCode.text
|
|
27
|
+
: fs.readFileSync(filePath, "utf8");
|
|
28
|
+
return {
|
|
29
|
+
filePath,
|
|
30
|
+
name: getPromptName(filePath, extractFrontmatter(sourceText)),
|
|
31
|
+
};
|
|
32
|
+
}), normalizeNameForComparison);
|
|
33
|
+
const currentPromptName = getPromptName(context.filename, extractFrontmatter(context.sourceCode.text));
|
|
34
|
+
const duplicateGroup = duplicateGroups.get(normalizeNameForComparison(currentPromptName));
|
|
35
|
+
if (duplicateGroup === undefined) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
reportAtDocumentStart(context, {
|
|
39
|
+
data: {
|
|
40
|
+
files: duplicateGroup
|
|
41
|
+
.map((entry) => normalizeRelativeFilePath(repositoryRoot, entry.filePath))
|
|
42
|
+
.join(", "),
|
|
43
|
+
name: currentPromptName,
|
|
44
|
+
},
|
|
45
|
+
messageId: "duplicatePromptName",
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
},
|
|
49
|
+
defaultOptions: [],
|
|
50
|
+
meta: {
|
|
51
|
+
deprecated: false,
|
|
52
|
+
docs: {
|
|
53
|
+
copilotConfigs: [
|
|
54
|
+
"copilot.configs.recommended",
|
|
55
|
+
"copilot.configs.strict",
|
|
56
|
+
"copilot.configs.all",
|
|
57
|
+
],
|
|
58
|
+
description: "disallow duplicate effective prompt names across workspace prompt files.",
|
|
59
|
+
frozen: false,
|
|
60
|
+
recommended: true,
|
|
61
|
+
requiresTypeChecking: false,
|
|
62
|
+
},
|
|
63
|
+
messages: {
|
|
64
|
+
duplicatePromptName: "Copilot prompt name `{{name}}` is duplicated across prompt files: {{files}}.",
|
|
65
|
+
},
|
|
66
|
+
schema: [],
|
|
67
|
+
type: "problem",
|
|
68
|
+
},
|
|
69
|
+
name: "no-duplicate-prompt-names",
|
|
70
|
+
});
|
|
71
|
+
export default noDuplicatePromptNamesRule;
|
|
72
|
+
//# sourceMappingURL=no-duplicate-prompt-names.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-duplicate-prompt-names.js","sourceRoot":"","sources":["../../src/rules/no-duplicate-prompt-names.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,SAAS,CAAC;AAC9B;;;GAGG;AACH,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAIlC,OAAO,EACH,aAAa,EACb,0BAA0B,GAC7B,MAAM,6CAA6C,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;AAC7E,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,yBAAyB,GAAG,CAC9B,cAAsB,EACtB,QAAgB,EACV,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;AAE3E,MAAM,0BAA0B,GAAsB,iBAAiB,CAAC;IACpE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACX,CAAC;YAED,MAAM,cAAc,GAAG,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAC5D,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAC7B,cAAc,EACd,SAAS,EACT,SAAS,CACZ,CAAC;YACF,MAAM,WAAW,GAAG,oBAAoB,CACpC,eAAe,EACf,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC,CAChD,CAAC;YACF,MAAM,eAAe,GAAG,0BAA0B,CAC9C,WAAW,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;gBACzB,MAAM,UAAU,GACZ,OAAO,CAAC,QAAQ,KAAK,QAAQ;oBACzB,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI;oBACzB,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;gBAE5C,OAAO;oBACH,QAAQ;oBACR,IAAI,EAAE,aAAa,CACf,QAAQ,EACR,kBAAkB,CAAC,UAAU,CAAC,CACjC;iBACJ,CAAC;YACN,CAAC,CAAC,EACF,0BAA0B,CAC7B,CAAC;YACF,MAAM,iBAAiB,GAAG,aAAa,CACnC,OAAO,CAAC,QAAQ,EAChB,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAC9C,CAAC;YACF,MAAM,cAAc,GAAG,eAAe,CAAC,GAAG,CACtC,0BAA0B,CAAC,iBAAiB,CAAC,CAChD,CAAC;YAEF,IAAI,cAAc,KAAK,SAAS,EAAE,CAAC;gBAC/B,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,KAAK,EAAE,cAAc;yBAChB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACX,yBAAyB,CACrB,cAAc,EACd,KAAK,CAAC,QAAQ,CACjB,CACJ;yBACA,IAAI,CAAC,IAAI,CAAC;oBACf,IAAI,EAAE,iBAAiB;iBAC1B;gBACD,SAAS,EAAE,qBAAqB;aACnC,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,0EAA0E;YAC9E,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,mBAAmB,EACf,8EAA8E;SACrF;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,2BAA2B;CACpC,CAAC,CAAC;AAEH,eAAe,0BAA0B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-duplicate-skill-names.d.ts","sourceRoot":"","sources":["../../src/rules/no-duplicate-skill-names.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAwB7E,QAAA,MAAM,yBAAyB,EAAE,iBAsF/B,CAAC;AAEH,eAAe,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `no-duplicate-skill-names`.
|
|
4
|
+
*/
|
|
5
|
+
import * as fs from "node:fs";
|
|
6
|
+
import * as path from "node:path";
|
|
7
|
+
import { getSkillName, normalizeNameForComparison, } from "../_internal/copilot-customization-names.js";
|
|
8
|
+
import { findRepositoryRoot, isSkillFilePath, } from "../_internal/copilot-file-kind.js";
|
|
9
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
10
|
+
import { collectDuplicateNameGroups } from "../_internal/duplicate-names.js";
|
|
11
|
+
import { listFilesRecursively } from "../_internal/file-system.js";
|
|
12
|
+
import { extractFrontmatter } from "../_internal/frontmatter.js";
|
|
13
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
14
|
+
const normalizeRelativeFilePath = (repositoryRoot, filePath) => path.relative(repositoryRoot, filePath).replaceAll("\\", "/");
|
|
15
|
+
const noDuplicateSkillNamesRule = createCopilotRule({
|
|
16
|
+
create(context) {
|
|
17
|
+
return createMarkdownDocumentListener(() => {
|
|
18
|
+
if (!isSkillFilePath(context.filename)) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const repositoryRoot = findRepositoryRoot(context.filename);
|
|
22
|
+
const skillFiles = [
|
|
23
|
+
...listFilesRecursively(path.join(repositoryRoot, ".github", "skills"), (filePath) => path.basename(filePath) === "SKILL.md"),
|
|
24
|
+
...listFilesRecursively(path.join(repositoryRoot, ".claude", "skills"), (filePath) => path.basename(filePath) === "SKILL.md"),
|
|
25
|
+
];
|
|
26
|
+
const duplicateGroups = collectDuplicateNameGroups(skillFiles.map((filePath) => {
|
|
27
|
+
const sourceText = context.filename === filePath
|
|
28
|
+
? context.sourceCode.text
|
|
29
|
+
: fs.readFileSync(filePath, "utf8");
|
|
30
|
+
return {
|
|
31
|
+
filePath,
|
|
32
|
+
name: getSkillName(filePath, extractFrontmatter(sourceText)),
|
|
33
|
+
};
|
|
34
|
+
}), normalizeNameForComparison);
|
|
35
|
+
const currentSkillName = getSkillName(context.filename, extractFrontmatter(context.sourceCode.text));
|
|
36
|
+
const duplicateGroup = duplicateGroups.get(normalizeNameForComparison(currentSkillName));
|
|
37
|
+
if (duplicateGroup === undefined) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
reportAtDocumentStart(context, {
|
|
41
|
+
data: {
|
|
42
|
+
files: duplicateGroup
|
|
43
|
+
.map((entry) => normalizeRelativeFilePath(repositoryRoot, entry.filePath))
|
|
44
|
+
.join(", "),
|
|
45
|
+
name: currentSkillName,
|
|
46
|
+
},
|
|
47
|
+
messageId: "duplicateSkillName",
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
},
|
|
51
|
+
defaultOptions: [],
|
|
52
|
+
meta: {
|
|
53
|
+
deprecated: false,
|
|
54
|
+
docs: {
|
|
55
|
+
copilotConfigs: [
|
|
56
|
+
"copilot.configs.recommended",
|
|
57
|
+
"copilot.configs.strict",
|
|
58
|
+
"copilot.configs.all",
|
|
59
|
+
],
|
|
60
|
+
description: "disallow duplicate effective skill names across project skill definition files.",
|
|
61
|
+
frozen: false,
|
|
62
|
+
recommended: true,
|
|
63
|
+
requiresTypeChecking: false,
|
|
64
|
+
},
|
|
65
|
+
messages: {
|
|
66
|
+
duplicateSkillName: "Copilot skill name `{{name}}` is duplicated across skill files: {{files}}.",
|
|
67
|
+
},
|
|
68
|
+
schema: [],
|
|
69
|
+
type: "problem",
|
|
70
|
+
},
|
|
71
|
+
name: "no-duplicate-skill-names",
|
|
72
|
+
});
|
|
73
|
+
export default noDuplicateSkillNamesRule;
|
|
74
|
+
//# sourceMappingURL=no-duplicate-skill-names.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-duplicate-skill-names.js","sourceRoot":"","sources":["../../src/rules/no-duplicate-skill-names.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-duplicate-slash-command-names.d.ts","sourceRoot":"","sources":["../../src/rules/no-duplicate-slash-command-names.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AA4B7E,QAAA,MAAM,gCAAgC,EAAE,iBA0FtC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `no-duplicate-slash-command-names`.
|
|
4
|
+
*/
|
|
5
|
+
import * as fs from "node:fs";
|
|
6
|
+
import * as path from "node:path";
|
|
7
|
+
import { getPromptName, getSkillName, normalizeNameForComparison, } from "../_internal/copilot-customization-names.js";
|
|
8
|
+
import { findRepositoryRoot, isSkillFilePath, } from "../_internal/copilot-file-kind.js";
|
|
9
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
10
|
+
import { collectDuplicateNameGroups } from "../_internal/duplicate-names.js";
|
|
11
|
+
import { listFilesRecursively } from "../_internal/file-system.js";
|
|
12
|
+
import { extractFrontmatter } from "../_internal/frontmatter.js";
|
|
13
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
14
|
+
const isPromptOrSkillCommandFile = (filePath) => filePath.endsWith(".prompt.md") || isSkillFilePath(filePath);
|
|
15
|
+
const normalizeRelativeFilePath = (repositoryRoot, filePath) => path.relative(repositoryRoot, filePath).replaceAll("\\", "/");
|
|
16
|
+
const noDuplicateSlashCommandNamesRule = createCopilotRule({
|
|
17
|
+
create(context) {
|
|
18
|
+
return createMarkdownDocumentListener(() => {
|
|
19
|
+
if (!isPromptOrSkillCommandFile(context.filename)) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const repositoryRoot = findRepositoryRoot(context.filename);
|
|
23
|
+
const commandFiles = [
|
|
24
|
+
...listFilesRecursively(path.join(repositoryRoot, ".github", "prompts"), (filePath) => filePath.endsWith(".prompt.md")),
|
|
25
|
+
...listFilesRecursively(path.join(repositoryRoot, ".github", "skills"), (filePath) => path.basename(filePath) === "SKILL.md"),
|
|
26
|
+
...listFilesRecursively(path.join(repositoryRoot, ".claude", "skills"), (filePath) => path.basename(filePath) === "SKILL.md"),
|
|
27
|
+
];
|
|
28
|
+
const duplicateGroups = collectDuplicateNameGroups(commandFiles.map((filePath) => {
|
|
29
|
+
const sourceText = context.filename === filePath
|
|
30
|
+
? context.sourceCode.text
|
|
31
|
+
: fs.readFileSync(filePath, "utf8");
|
|
32
|
+
const frontmatter = extractFrontmatter(sourceText);
|
|
33
|
+
return {
|
|
34
|
+
filePath,
|
|
35
|
+
name: filePath.endsWith(".prompt.md")
|
|
36
|
+
? getPromptName(filePath, frontmatter)
|
|
37
|
+
: getSkillName(filePath, frontmatter),
|
|
38
|
+
};
|
|
39
|
+
}), normalizeNameForComparison);
|
|
40
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
41
|
+
const currentCommandName = context.filename.endsWith(".prompt.md")
|
|
42
|
+
? getPromptName(context.filename, frontmatter)
|
|
43
|
+
: getSkillName(context.filename, frontmatter);
|
|
44
|
+
const duplicateGroup = duplicateGroups.get(normalizeNameForComparison(currentCommandName));
|
|
45
|
+
if (duplicateGroup === undefined) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
reportAtDocumentStart(context, {
|
|
49
|
+
data: {
|
|
50
|
+
files: duplicateGroup
|
|
51
|
+
.map((entry) => normalizeRelativeFilePath(repositoryRoot, entry.filePath))
|
|
52
|
+
.join(", "),
|
|
53
|
+
name: currentCommandName,
|
|
54
|
+
},
|
|
55
|
+
messageId: "duplicateSlashCommandName",
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
},
|
|
59
|
+
defaultOptions: [],
|
|
60
|
+
meta: {
|
|
61
|
+
deprecated: false,
|
|
62
|
+
docs: {
|
|
63
|
+
copilotConfigs: [
|
|
64
|
+
"copilot.configs.recommended",
|
|
65
|
+
"copilot.configs.strict",
|
|
66
|
+
"copilot.configs.all",
|
|
67
|
+
],
|
|
68
|
+
description: "disallow duplicate slash-command names across prompt files and skills.",
|
|
69
|
+
frozen: false,
|
|
70
|
+
recommended: true,
|
|
71
|
+
requiresTypeChecking: false,
|
|
72
|
+
},
|
|
73
|
+
messages: {
|
|
74
|
+
duplicateSlashCommandName: "Slash command name `{{name}}` is duplicated across prompt or skill files: {{files}}.",
|
|
75
|
+
},
|
|
76
|
+
schema: [],
|
|
77
|
+
type: "problem",
|
|
78
|
+
},
|
|
79
|
+
name: "no-duplicate-slash-command-names",
|
|
80
|
+
});
|
|
81
|
+
export default noDuplicateSlashCommandNamesRule;
|
|
82
|
+
//# sourceMappingURL=no-duplicate-slash-command-names.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-duplicate-slash-command-names.js","sourceRoot":"","sources":["../../src/rules/no-duplicate-slash-command-names.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-empty-repository-hook-arrays.d.ts","sourceRoot":"","sources":["../../src/rules/no-empty-repository-hook-arrays.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAe7E,QAAA,MAAM,+BAA+B,EAAE,iBA8CrC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `no-empty-repository-hook-arrays`.
|
|
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 { getRepositoryHookEventEntries, isJsonArray, parseJsonText, } from "../_internal/repository-hooks-json.js";
|
|
9
|
+
const noEmptyRepositoryHookArraysRule = 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 emptyEntry = getRepositoryHookEventEntries(root).find(([, eventValue]) => isJsonArray(eventValue) && eventValue.length === 0);
|
|
18
|
+
if (emptyEntry === undefined) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
reportAtDocumentStart(context, {
|
|
22
|
+
data: {
|
|
23
|
+
eventName: emptyEntry[0],
|
|
24
|
+
},
|
|
25
|
+
messageId: "emptyRepositoryHookArray",
|
|
26
|
+
});
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
},
|
|
30
|
+
defaultOptions: [],
|
|
31
|
+
meta: {
|
|
32
|
+
deprecated: false,
|
|
33
|
+
docs: {
|
|
34
|
+
copilotConfigs: ["copilot.configs.strict", "copilot.configs.all"],
|
|
35
|
+
description: "disallow empty repository hook arrays that opt into an event without any hook definitions.",
|
|
36
|
+
frozen: false,
|
|
37
|
+
recommended: false,
|
|
38
|
+
requiresTypeChecking: false,
|
|
39
|
+
},
|
|
40
|
+
messages: {
|
|
41
|
+
emptyRepositoryHookArray: "Repository hook event `{{eventName}}` should not be declared with an empty array.",
|
|
42
|
+
},
|
|
43
|
+
schema: [],
|
|
44
|
+
type: "problem",
|
|
45
|
+
},
|
|
46
|
+
name: "no-empty-repository-hook-arrays",
|
|
47
|
+
});
|
|
48
|
+
export default noEmptyRepositoryHookArraysRule;
|
|
49
|
+
//# sourceMappingURL=no-empty-repository-hook-arrays.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-empty-repository-hook-arrays.js","sourceRoot":"","sources":["../../src/rules/no-empty-repository-hook-arrays.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,6BAA6B,EAC7B,WAAW,EACX,aAAa,GAChB,MAAM,uCAAuC,CAAC;AAE/C,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,UAAU,CAAC,MAAM,KAAK,CAAC,CACzD,CAAC;gBAEF,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;oBAC3B,OAAO;gBACX,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC;qBAC3B;oBACD,SAAS,EAAE,0BAA0B;iBACxC,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,CAAC,wBAAwB,EAAE,qBAAqB,CAAC;YACjE,WAAW,EACP,4FAA4F;YAChG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;SAC9B;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"}
|
|
@@ -0,0 +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;AAa7E,QAAA,MAAM,yBAAyB,EAAE,iBAmC/B,CAAC;AAEH,eAAe,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `no-legacy-chatmode-files`.
|
|
4
|
+
*/
|
|
5
|
+
import { isLegacyChatmodeFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
8
|
+
const noLegacyChatmodeFilesRule = createCopilotRule({
|
|
9
|
+
create(context) {
|
|
10
|
+
return createMarkdownDocumentListener(() => {
|
|
11
|
+
if (!isLegacyChatmodeFilePath(context.filename)) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
reportAtDocumentStart(context, {
|
|
15
|
+
messageId: "legacyChatmodeFile",
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
},
|
|
19
|
+
defaultOptions: [],
|
|
20
|
+
meta: {
|
|
21
|
+
deprecated: false,
|
|
22
|
+
docs: {
|
|
23
|
+
copilotConfigs: [
|
|
24
|
+
"copilot.configs.recommended",
|
|
25
|
+
"copilot.configs.strict",
|
|
26
|
+
"copilot.configs.all",
|
|
27
|
+
],
|
|
28
|
+
description: "disallow legacy Copilot `.chatmode.md` files in favor of modern `.agent.md` custom agents.",
|
|
29
|
+
frozen: false,
|
|
30
|
+
recommended: true,
|
|
31
|
+
requiresTypeChecking: false,
|
|
32
|
+
},
|
|
33
|
+
messages: {
|
|
34
|
+
legacyChatmodeFile: "Legacy Copilot `.chatmode.md` files should be migrated to `.github/agents/*.agent.md` custom agents.",
|
|
35
|
+
},
|
|
36
|
+
schema: [],
|
|
37
|
+
type: "suggestion",
|
|
38
|
+
},
|
|
39
|
+
name: "no-legacy-chatmode-files",
|
|
40
|
+
});
|
|
41
|
+
export default noLegacyChatmodeFilesRule;
|
|
42
|
+
//# sourceMappingURL=no-legacy-chatmode-files.js.map
|
|
@@ -0,0 +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;AAEvC,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,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,4FAA4F;YAChG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
declare const preferCustomInstructionsUnderCodeReviewLimitRule: CopilotRuleModule;
|
|
3
|
+
export default preferCustomInstructionsUnderCodeReviewLimitRule;
|
|
4
|
+
//# sourceMappingURL=prefer-custom-instructions-under-code-review-limit.d.ts.map
|
|
@@ -0,0 +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;AAe7E,QAAA,MAAM,gDAAgD,EAAE,iBAoDlD,CAAC;AAEP,eAAe,gDAAgD,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { getCopilotFileKind } from "../_internal/copilot-file-kind.js";
|
|
2
|
+
/**
|
|
3
|
+
* @packageDocumentation
|
|
4
|
+
* ESLint rule implementation for `prefer-custom-instructions-under-code-review-limit`.
|
|
5
|
+
*/
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
8
|
+
const CODE_REVIEW_CUSTOM_INSTRUCTIONS_LIMIT = 4000;
|
|
9
|
+
const preferCustomInstructionsUnderCodeReviewLimitRule = createCopilotRule({
|
|
10
|
+
create(context) {
|
|
11
|
+
return createMarkdownDocumentListener(() => {
|
|
12
|
+
const fileKind = getCopilotFileKind(context.filename);
|
|
13
|
+
if (fileKind !== "instructions" &&
|
|
14
|
+
fileKind !== "repository-instructions") {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const characterCount = context.sourceCode.text.length;
|
|
18
|
+
if (characterCount <= CODE_REVIEW_CUSTOM_INSTRUCTIONS_LIMIT) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
reportAtDocumentStart(context, {
|
|
22
|
+
data: {
|
|
23
|
+
characterCount: String(characterCount),
|
|
24
|
+
maxCharacters: String(CODE_REVIEW_CUSTOM_INSTRUCTIONS_LIMIT),
|
|
25
|
+
},
|
|
26
|
+
messageId: "exceedsCodeReviewLimit",
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
},
|
|
30
|
+
defaultOptions: [],
|
|
31
|
+
meta: {
|
|
32
|
+
deprecated: false,
|
|
33
|
+
docs: {
|
|
34
|
+
copilotConfigs: [
|
|
35
|
+
"copilot.configs.strict",
|
|
36
|
+
"copilot.configs.all",
|
|
37
|
+
],
|
|
38
|
+
description: "enforce repository and path-specific Copilot instruction files staying within the 4,000-character code-review instruction budget.",
|
|
39
|
+
frozen: false,
|
|
40
|
+
recommended: false,
|
|
41
|
+
requiresTypeChecking: false,
|
|
42
|
+
},
|
|
43
|
+
messages: {
|
|
44
|
+
exceedsCodeReviewLimit: "Copilot code review only reads roughly the first {{maxCharacters}} characters of custom instructions; this file is {{characterCount}} characters long.",
|
|
45
|
+
},
|
|
46
|
+
schema: [],
|
|
47
|
+
type: "suggestion",
|
|
48
|
+
},
|
|
49
|
+
name: "prefer-custom-instructions-under-code-review-limit",
|
|
50
|
+
});
|
|
51
|
+
export default preferCustomInstructionsUnderCodeReviewLimitRule;
|
|
52
|
+
//# sourceMappingURL=prefer-custom-instructions-under-code-review-limit.js.map
|
|
@@ -0,0 +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;AAEvC,MAAM,qCAAqC,GAAG,IAAI,CAAC;AAEnD,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,cAAc,EAAE,EAAE;IAClB,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;SAC9B;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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prefer-fast-repository-hooks.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-fast-repository-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAgB7E,QAAA,MAAM,6BAA6B,EAAE,iBA2DnC,CAAC;AAEH,eAAe,6BAA6B,CAAC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `prefer-fast-repository-hooks`.
|
|
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 { DEFAULT_REPOSITORY_HOOK_TIMEOUT_SECONDS, getRepositoryHookObjects, isJsonNumber, parseJsonText, } from "../_internal/repository-hooks-json.js";
|
|
9
|
+
const preferFastRepositoryHooksRule = 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 slowHook = getRepositoryHookObjects(root).find(({ hook }) => {
|
|
18
|
+
const timeout = hook["timeoutSec"];
|
|
19
|
+
return (isJsonNumber(timeout) &&
|
|
20
|
+
timeout > DEFAULT_REPOSITORY_HOOK_TIMEOUT_SECONDS);
|
|
21
|
+
});
|
|
22
|
+
if (slowHook === undefined) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const timeout = slowHook.hook["timeoutSec"];
|
|
26
|
+
if (!isJsonNumber(timeout)) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
reportAtDocumentStart(context, {
|
|
30
|
+
data: {
|
|
31
|
+
eventName: slowHook.eventName,
|
|
32
|
+
timeout: String(timeout),
|
|
33
|
+
},
|
|
34
|
+
messageId: "slowRepositoryHookTimeout",
|
|
35
|
+
});
|
|
36
|
+
},
|
|
37
|
+
};
|
|
38
|
+
},
|
|
39
|
+
defaultOptions: [],
|
|
40
|
+
meta: {
|
|
41
|
+
deprecated: false,
|
|
42
|
+
docs: {
|
|
43
|
+
copilotConfigs: ["copilot.configs.strict", "copilot.configs.all"],
|
|
44
|
+
description: "enforce repository hooks staying at or below the default 30-second timeout unless a slower hook is truly necessary.",
|
|
45
|
+
frozen: false,
|
|
46
|
+
recommended: false,
|
|
47
|
+
requiresTypeChecking: false,
|
|
48
|
+
},
|
|
49
|
+
messages: {
|
|
50
|
+
slowRepositoryHookTimeout: "Repository hook `timeoutSec` for `{{eventName}}` is {{timeout}} seconds, which exceeds the default 30-second timeout budget.",
|
|
51
|
+
},
|
|
52
|
+
schema: [],
|
|
53
|
+
type: "suggestion",
|
|
54
|
+
},
|
|
55
|
+
name: "prefer-fast-repository-hooks",
|
|
56
|
+
});
|
|
57
|
+
export default preferFastRepositoryHooksRule;
|
|
58
|
+
//# sourceMappingURL=prefer-fast-repository-hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prefer-fast-repository-hooks.js","sourceRoot":"","sources":["../../src/rules/prefer-fast-repository-hooks.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,uCAAuC,EACvC,wBAAwB,EACxB,YAAY,EACZ,aAAa,GAChB,MAAM,uCAAuC,CAAC;AAE/C,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,QAAQ,KAAK,SAAS,EAAE,CAAC;oBACzB,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,cAAc,EAAE,EAAE;IAClB,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;SAC9B;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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prefer-qualified-tools.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-qualified-tools.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAsB7E,QAAA,MAAM,wBAAwB,EAAE,iBAwD9B,CAAC;AAEH,eAAe,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { getCopilotFileKind } from "../_internal/copilot-file-kind.js";
|
|
2
|
+
/**
|
|
3
|
+
* @packageDocumentation
|
|
4
|
+
* ESLint rule implementation for `prefer-qualified-tools`.
|
|
5
|
+
*/
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterList, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const isQualifiedToolName = (toolName) => toolName.includes("/");
|
|
10
|
+
const allowedUnqualifiedToolNames = new Set(["agent", "runSubagent"]);
|
|
11
|
+
const preferQualifiedToolsRule = createCopilotRule({
|
|
12
|
+
create(context) {
|
|
13
|
+
return createMarkdownDocumentListener(() => {
|
|
14
|
+
const fileKind = getCopilotFileKind(context.filename);
|
|
15
|
+
if (fileKind !== "chatmode" && fileKind !== "prompt") {
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
19
|
+
if (frontmatter === null) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const tools = getFrontmatterList(frontmatter, "tools");
|
|
23
|
+
if (tools === undefined) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const firstUnqualifiedTool = tools.find((toolName) => !isQualifiedToolName(toolName) &&
|
|
27
|
+
!allowedUnqualifiedToolNames.has(toolName));
|
|
28
|
+
if (firstUnqualifiedTool === undefined) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
reportAtDocumentStart(context, {
|
|
32
|
+
data: { toolName: firstUnqualifiedTool },
|
|
33
|
+
messageId: "preferQualifiedTool",
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
},
|
|
37
|
+
defaultOptions: [],
|
|
38
|
+
meta: {
|
|
39
|
+
deprecated: false,
|
|
40
|
+
docs: {
|
|
41
|
+
copilotConfigs: ["copilot.configs.all"],
|
|
42
|
+
description: "enforce fully-qualified tool names in Copilot prompt files, custom agents, and legacy chat modes.",
|
|
43
|
+
frozen: false,
|
|
44
|
+
recommended: false,
|
|
45
|
+
requiresTypeChecking: false,
|
|
46
|
+
},
|
|
47
|
+
messages: {
|
|
48
|
+
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`.",
|
|
49
|
+
},
|
|
50
|
+
schema: [],
|
|
51
|
+
type: "suggestion",
|
|
52
|
+
},
|
|
53
|
+
name: "prefer-qualified-tools",
|
|
54
|
+
});
|
|
55
|
+
export default preferQualifiedToolsRule;
|
|
56
|
+
//# sourceMappingURL=prefer-qualified-tools.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prefer-qualified-tools.js","sourceRoot":"","sources":["../../src/rules/prefer-qualified-tools.ts"],"names":[],"mappings":"AAEA,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;AAEvC,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,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,KAAK,KAAK,SAAS,EAAE,CAAC;gBACtB,OAAO;YACX,CAAC;YAED,MAAM,oBAAoB,GAAG,KAAK,CAAC,IAAI,CACnC,CAAC,QAAQ,EAAE,EAAE,CACT,CAAC,mBAAmB,CAAC,QAAQ,CAAC;gBAC9B,CAAC,2BAA2B,CAAC,GAAG,CAAC,QAAQ,CAAC,CACjD,CAAC;YAEF,IAAI,oBAAoB,KAAK,SAAS,EAAE,CAAC;gBACrC,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,cAAc,EAAE,EAAE;IAClB,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;SAC9B;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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-agent-tool-for-subagents.d.ts","sourceRoot":"","sources":["../../src/rules/require-agent-tool-for-subagents.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAsB7E,QAAA,MAAM,gCAAgC,EAAE,iBAiEtC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
|