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 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-handoffs.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoffs.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAiB7E,QAAA,MAAM,6BAA6B,EAAE,iBAkFnC,CAAC;AAEH,eAAe,6BAA6B,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `require-valid-agent-handoffs`.
|
|
4
|
+
*/
|
|
5
|
+
import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterObjectList, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const requireValidAgentHandoffsRule = createCopilotRule({
|
|
10
|
+
create(context) {
|
|
11
|
+
return createMarkdownDocumentListener(() => {
|
|
12
|
+
if (!isCustomAgentFilePath(context.filename)) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
16
|
+
if (frontmatter === null) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const handoffs = getFrontmatterObjectList(frontmatter, "handoffs");
|
|
20
|
+
if (handoffs === undefined || handoffs.length === 0) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
for (const [index, handoff] of handoffs.entries()) {
|
|
24
|
+
const handoffNumber = String(index + 1);
|
|
25
|
+
const label = handoff["label"]?.trim() ?? "";
|
|
26
|
+
const agent = handoff["agent"]?.trim() ?? "";
|
|
27
|
+
const prompt = handoff["prompt"]?.trim() ?? "";
|
|
28
|
+
const send = handoff["send"]?.trim().toLowerCase() ?? "";
|
|
29
|
+
if (label.length === 0) {
|
|
30
|
+
reportAtDocumentStart(context, {
|
|
31
|
+
data: { handoffNumber },
|
|
32
|
+
messageId: "missingLabel",
|
|
33
|
+
});
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
if (agent.length === 0) {
|
|
37
|
+
reportAtDocumentStart(context, {
|
|
38
|
+
data: { handoffNumber },
|
|
39
|
+
messageId: "missingAgent",
|
|
40
|
+
});
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
if (send === "true" && prompt.length === 0) {
|
|
44
|
+
reportAtDocumentStart(context, {
|
|
45
|
+
data: { handoffNumber },
|
|
46
|
+
messageId: "missingPromptForAutoSend",
|
|
47
|
+
});
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
},
|
|
53
|
+
defaultOptions: [],
|
|
54
|
+
meta: {
|
|
55
|
+
deprecated: false,
|
|
56
|
+
docs: {
|
|
57
|
+
copilotConfigs: [
|
|
58
|
+
"copilot.configs.recommended",
|
|
59
|
+
"copilot.configs.strict",
|
|
60
|
+
"copilot.configs.all",
|
|
61
|
+
],
|
|
62
|
+
description: "require Copilot custom-agent handoffs to define the metadata needed for usable guided transitions.",
|
|
63
|
+
frozen: false,
|
|
64
|
+
recommended: true,
|
|
65
|
+
requiresTypeChecking: false,
|
|
66
|
+
},
|
|
67
|
+
messages: {
|
|
68
|
+
missingAgent: "Copilot custom agent handoff #{{handoffNumber}} must define a non-empty `agent` target.",
|
|
69
|
+
missingLabel: "Copilot custom agent handoff #{{handoffNumber}} must define a non-empty `label`.",
|
|
70
|
+
missingPromptForAutoSend: "Copilot custom agent handoff #{{handoffNumber}} with `send: true` must also define a non-empty `prompt`.",
|
|
71
|
+
},
|
|
72
|
+
schema: [],
|
|
73
|
+
type: "problem",
|
|
74
|
+
},
|
|
75
|
+
name: "require-valid-agent-handoffs",
|
|
76
|
+
});
|
|
77
|
+
export default requireValidAgentHandoffsRule;
|
|
78
|
+
//# sourceMappingURL=require-valid-agent-handoffs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-handoffs.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoffs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hook-events.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-events.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AA4B7E,QAAA,MAAM,+BAA+B,EAAE,iBA2DrC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `require-valid-agent-hook-events`.
|
|
4
|
+
*/
|
|
5
|
+
import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterObjectListGroups, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const VALID_HOOK_EVENT_NAMES = new Set([
|
|
10
|
+
"PostToolUse",
|
|
11
|
+
"PreCompact",
|
|
12
|
+
"PreToolUse",
|
|
13
|
+
"SessionStart",
|
|
14
|
+
"Stop",
|
|
15
|
+
"SubagentStart",
|
|
16
|
+
"SubagentStop",
|
|
17
|
+
"UserPromptSubmit",
|
|
18
|
+
]);
|
|
19
|
+
const requireValidAgentHookEventsRule = createCopilotRule({
|
|
20
|
+
create(context) {
|
|
21
|
+
return createMarkdownDocumentListener(() => {
|
|
22
|
+
if (!isCustomAgentFilePath(context.filename)) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
26
|
+
if (frontmatter === null) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
const hookGroups = getFrontmatterObjectListGroups(frontmatter, "hooks");
|
|
30
|
+
if (hookGroups === undefined || hookGroups.size === 0) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
for (const eventName of hookGroups.keys()) {
|
|
34
|
+
if (VALID_HOOK_EVENT_NAMES.has(eventName)) {
|
|
35
|
+
continue;
|
|
36
|
+
}
|
|
37
|
+
reportAtDocumentStart(context, {
|
|
38
|
+
data: { eventName },
|
|
39
|
+
messageId: "invalidHookEvent",
|
|
40
|
+
});
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
},
|
|
45
|
+
defaultOptions: [],
|
|
46
|
+
meta: {
|
|
47
|
+
deprecated: false,
|
|
48
|
+
docs: {
|
|
49
|
+
copilotConfigs: [
|
|
50
|
+
"copilot.configs.recommended",
|
|
51
|
+
"copilot.configs.strict",
|
|
52
|
+
"copilot.configs.all",
|
|
53
|
+
],
|
|
54
|
+
description: "require Copilot custom-agent hooks to use supported VS Code hook event names.",
|
|
55
|
+
frozen: false,
|
|
56
|
+
recommended: true,
|
|
57
|
+
requiresTypeChecking: false,
|
|
58
|
+
},
|
|
59
|
+
messages: {
|
|
60
|
+
invalidHookEvent: "Copilot custom agent hooks should use a supported event name, not `{{eventName}}`.",
|
|
61
|
+
},
|
|
62
|
+
schema: [],
|
|
63
|
+
type: "problem",
|
|
64
|
+
},
|
|
65
|
+
name: "require-valid-agent-hook-events",
|
|
66
|
+
});
|
|
67
|
+
export default requireValidAgentHookEventsRule;
|
|
68
|
+
//# sourceMappingURL=require-valid-agent-hook-events.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hook-events.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-events.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,8BAA8B,GACjC,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,sBAAsB,GAAG,IAAI,GAAG,CAAC;IACnC,aAAa;IACb,YAAY;IACZ,YAAY;IACZ,cAAc;IACd,MAAM;IACN,eAAe;IACf,cAAc;IACd,kBAAkB;CACrB,CAAC,CAAC;AAEH,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;YAEhE,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;gBACvB,OAAO;YACX,CAAC;YAED,MAAM,UAAU,GAAG,8BAA8B,CAC7C,WAAW,EACX,OAAO,CACV,CAAC;YAEF,IAAI,UAAU,KAAK,SAAS,IAAI,UAAU,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;gBACpD,OAAO;YACX,CAAC;YAED,KAAK,MAAM,SAAS,IAAI,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC;gBACxC,IAAI,sBAAsB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;oBACxC,SAAS;gBACb,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE,EAAE,SAAS,EAAE;oBACnB,SAAS,EAAE,kBAAkB;iBAChC,CAAC,CAAC;gBAEH,OAAO;YACX,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,+EAA+E;YACnF,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,gBAAgB,EACZ,oFAAoF;SAC3F;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":"require-valid-agent-hook-timeouts.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-timeouts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAuC7E,QAAA,MAAM,iCAAiC,EAAE,iBAuEvC,CAAC;AAEH,eAAe,iCAAiC,CAAC"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `require-valid-agent-hook-timeouts`.
|
|
4
|
+
*/
|
|
5
|
+
import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterObjectListGroups, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const isNumericTimeoutValue = (value) => {
|
|
10
|
+
let decimalPointCount = 0;
|
|
11
|
+
for (const character of value) {
|
|
12
|
+
if (character === ".") {
|
|
13
|
+
decimalPointCount += 1;
|
|
14
|
+
if (decimalPointCount > 1) {
|
|
15
|
+
return false;
|
|
16
|
+
}
|
|
17
|
+
continue;
|
|
18
|
+
}
|
|
19
|
+
if (character < "0" || character > "9") {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return value.length > 0 && !value.startsWith(".") && !value.endsWith(".");
|
|
24
|
+
};
|
|
25
|
+
const requireValidAgentHookTimeoutsRule = createCopilotRule({
|
|
26
|
+
create(context) {
|
|
27
|
+
return createMarkdownDocumentListener(() => {
|
|
28
|
+
if (!isCustomAgentFilePath(context.filename)) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
32
|
+
if (frontmatter === null) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
const hookGroups = getFrontmatterObjectListGroups(frontmatter, "hooks");
|
|
36
|
+
if (hookGroups === undefined || hookGroups.size === 0) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
for (const [eventName, hooks] of hookGroups) {
|
|
40
|
+
for (const [index, hook] of hooks.entries()) {
|
|
41
|
+
const timeout = hook["timeout"]?.trim();
|
|
42
|
+
if (timeout === undefined ||
|
|
43
|
+
timeout.length === 0 ||
|
|
44
|
+
isNumericTimeoutValue(timeout)) {
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
reportAtDocumentStart(context, {
|
|
48
|
+
data: {
|
|
49
|
+
eventName,
|
|
50
|
+
hookNumber: String(index + 1),
|
|
51
|
+
timeout,
|
|
52
|
+
},
|
|
53
|
+
messageId: "invalidHookTimeout",
|
|
54
|
+
});
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
},
|
|
60
|
+
defaultOptions: [],
|
|
61
|
+
meta: {
|
|
62
|
+
deprecated: false,
|
|
63
|
+
docs: {
|
|
64
|
+
copilotConfigs: [
|
|
65
|
+
"copilot.configs.recommended",
|
|
66
|
+
"copilot.configs.strict",
|
|
67
|
+
"copilot.configs.all",
|
|
68
|
+
],
|
|
69
|
+
description: "require Copilot custom-agent hook `timeout` values to be numeric seconds when present.",
|
|
70
|
+
frozen: false,
|
|
71
|
+
recommended: true,
|
|
72
|
+
requiresTypeChecking: false,
|
|
73
|
+
},
|
|
74
|
+
messages: {
|
|
75
|
+
invalidHookTimeout: "Copilot custom agent hook #{{hookNumber}} in `{{eventName}}` should use a numeric `timeout` value in seconds, not `{{timeout}}`.",
|
|
76
|
+
},
|
|
77
|
+
schema: [],
|
|
78
|
+
type: "problem",
|
|
79
|
+
},
|
|
80
|
+
name: "require-valid-agent-hook-timeouts",
|
|
81
|
+
});
|
|
82
|
+
export default requireValidAgentHookTimeoutsRule;
|
|
83
|
+
//# sourceMappingURL=require-valid-agent-hook-timeouts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hook-timeouts.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-timeouts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hooks.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AA6B7E,QAAA,MAAM,0BAA0B,EAAE,iBAkFhC,CAAC;AAEH,eAAe,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `require-valid-agent-hooks`.
|
|
4
|
+
*/
|
|
5
|
+
import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterObjectListGroups, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const hasAnyHookCommand = (hook) => [
|
|
10
|
+
"command",
|
|
11
|
+
"windows",
|
|
12
|
+
"linux",
|
|
13
|
+
"osx",
|
|
14
|
+
].some((key) => {
|
|
15
|
+
const value = hook[key];
|
|
16
|
+
return typeof value === "string" && value.trim().length > 0;
|
|
17
|
+
});
|
|
18
|
+
const requireValidAgentHooksRule = createCopilotRule({
|
|
19
|
+
create(context) {
|
|
20
|
+
return createMarkdownDocumentListener(() => {
|
|
21
|
+
if (!isCustomAgentFilePath(context.filename)) {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
25
|
+
if (frontmatter === null) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
const hookGroups = getFrontmatterObjectListGroups(frontmatter, "hooks");
|
|
29
|
+
if (hookGroups === undefined || hookGroups.size === 0) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
for (const [eventName, hooks] of hookGroups) {
|
|
33
|
+
for (const [index, hook] of hooks.entries()) {
|
|
34
|
+
const hookNumber = String(index + 1);
|
|
35
|
+
const type = hook["type"]?.trim() ?? "";
|
|
36
|
+
if (type !== "command") {
|
|
37
|
+
reportAtDocumentStart(context, {
|
|
38
|
+
data: {
|
|
39
|
+
eventName,
|
|
40
|
+
hookNumber,
|
|
41
|
+
type: type.length === 0 ? "(missing)" : type,
|
|
42
|
+
},
|
|
43
|
+
messageId: "invalidHookType",
|
|
44
|
+
});
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
if (hasAnyHookCommand(hook)) {
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
reportAtDocumentStart(context, {
|
|
51
|
+
data: {
|
|
52
|
+
eventName,
|
|
53
|
+
hookNumber,
|
|
54
|
+
},
|
|
55
|
+
messageId: "missingHookCommand",
|
|
56
|
+
});
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
},
|
|
62
|
+
defaultOptions: [],
|
|
63
|
+
meta: {
|
|
64
|
+
deprecated: false,
|
|
65
|
+
docs: {
|
|
66
|
+
copilotConfigs: [
|
|
67
|
+
"copilot.configs.recommended",
|
|
68
|
+
"copilot.configs.strict",
|
|
69
|
+
"copilot.configs.all",
|
|
70
|
+
],
|
|
71
|
+
description: "require Copilot custom-agent hooks to use `type: command` and define at least one command property.",
|
|
72
|
+
frozen: false,
|
|
73
|
+
recommended: true,
|
|
74
|
+
requiresTypeChecking: false,
|
|
75
|
+
},
|
|
76
|
+
messages: {
|
|
77
|
+
invalidHookType: "Copilot custom agent hook #{{hookNumber}} in `{{eventName}}` must use `type: command` (current value: `{{type}}`).",
|
|
78
|
+
missingHookCommand: "Copilot custom agent hook #{{hookNumber}} in `{{eventName}}` must define at least one command property (`command`, `windows`, `linux`, or `osx`).",
|
|
79
|
+
},
|
|
80
|
+
schema: [],
|
|
81
|
+
type: "problem",
|
|
82
|
+
},
|
|
83
|
+
name: "require-valid-agent-hooks",
|
|
84
|
+
});
|
|
85
|
+
export default requireValidAgentHooksRule;
|
|
86
|
+
//# sourceMappingURL=require-valid-agent-hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hooks.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hooks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
declare const requireValidAgentInvocationControlsRule: CopilotRuleModule;
|
|
3
|
+
export default requireValidAgentInvocationControlsRule;
|
|
4
|
+
//# sourceMappingURL=require-valid-agent-invocation-controls.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-invocation-controls.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-invocation-controls.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAyB7E,QAAA,MAAM,uCAAuC,EAAE,iBAuEzC,CAAC;AAEP,eAAe,uCAAuC,CAAC"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `require-valid-agent-invocation-controls`.
|
|
4
|
+
*/
|
|
5
|
+
import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const VALID_BOOLEAN_FIELD_VALUES = new Set(["false", "true"]);
|
|
10
|
+
const INVOCATION_CONTROL_FIELDS = [
|
|
11
|
+
"disable-model-invocation",
|
|
12
|
+
"user-invocable",
|
|
13
|
+
];
|
|
14
|
+
const requireValidAgentInvocationControlsRule = createCopilotRule({
|
|
15
|
+
create(context) {
|
|
16
|
+
return createMarkdownDocumentListener(() => {
|
|
17
|
+
if (!isCustomAgentFilePath(context.filename)) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
21
|
+
if (frontmatter === null) {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
for (const fieldName of INVOCATION_CONTROL_FIELDS) {
|
|
25
|
+
if (!hasFrontmatterField(frontmatter, fieldName)) {
|
|
26
|
+
continue;
|
|
27
|
+
}
|
|
28
|
+
const fieldValue = getFrontmatterScalar(frontmatter, fieldName);
|
|
29
|
+
const normalizedValue = fieldValue?.trim().toLowerCase();
|
|
30
|
+
if (normalizedValue !== undefined &&
|
|
31
|
+
VALID_BOOLEAN_FIELD_VALUES.has(normalizedValue)) {
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
reportAtDocumentStart(context, {
|
|
35
|
+
data: {
|
|
36
|
+
currentValue: fieldValue === undefined ||
|
|
37
|
+
fieldValue.trim().length === 0
|
|
38
|
+
? "(empty)"
|
|
39
|
+
: fieldValue,
|
|
40
|
+
fieldName,
|
|
41
|
+
},
|
|
42
|
+
messageId: "invalidInvocationControl",
|
|
43
|
+
});
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
},
|
|
48
|
+
defaultOptions: [],
|
|
49
|
+
meta: {
|
|
50
|
+
deprecated: false,
|
|
51
|
+
docs: {
|
|
52
|
+
copilotConfigs: [
|
|
53
|
+
"copilot.configs.recommended",
|
|
54
|
+
"copilot.configs.strict",
|
|
55
|
+
"copilot.configs.all",
|
|
56
|
+
],
|
|
57
|
+
description: "require Copilot custom-agent invocation-control flags to use documented boolean values when present.",
|
|
58
|
+
frozen: false,
|
|
59
|
+
recommended: true,
|
|
60
|
+
requiresTypeChecking: false,
|
|
61
|
+
},
|
|
62
|
+
messages: {
|
|
63
|
+
invalidInvocationControl: "Copilot custom agent `{{fieldName}}` must use a boolean `true` or `false` value (current value: `{{currentValue}}`).",
|
|
64
|
+
},
|
|
65
|
+
schema: [],
|
|
66
|
+
type: "problem",
|
|
67
|
+
},
|
|
68
|
+
name: "require-valid-agent-invocation-controls",
|
|
69
|
+
});
|
|
70
|
+
export default requireValidAgentInvocationControlsRule;
|
|
71
|
+
//# sourceMappingURL=require-valid-agent-invocation-controls.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-invocation-controls.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-invocation-controls.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,GACtB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,0BAA0B,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;AAE9D,MAAM,yBAAyB,GAAG;IAC9B,0BAA0B;IAC1B,gBAAgB;CACV,CAAC;AAEX,MAAM,uCAAuC,GACzC,iBAAiB,CAAC;IACd,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,KAAK,MAAM,SAAS,IAAI,yBAAyB,EAAE,CAAC;gBAChD,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,SAAS,CAAC,EAAE,CAAC;oBAC/C,SAAS;gBACb,CAAC;gBAED,MAAM,UAAU,GAAG,oBAAoB,CACnC,WAAW,EACX,SAAS,CACZ,CAAC;gBACF,MAAM,eAAe,GAAG,UAAU,EAAE,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAEzD,IACI,eAAe,KAAK,SAAS;oBAC7B,0BAA0B,CAAC,GAAG,CAAC,eAAe,CAAC,EACjD,CAAC;oBACC,SAAS;gBACb,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,YAAY,EACR,UAAU,KAAK,SAAS;4BACxB,UAAU,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC;4BAC1B,CAAC,CAAC,SAAS;4BACX,CAAC,CAAC,UAAU;wBACpB,SAAS;qBACZ;oBACD,SAAS,EAAE,0BAA0B;iBACxC,CAAC,CAAC;gBAEH,OAAO;YACX,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,cAAc,EAAE,EAAE;IAClB,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,sGAAsG;YAC1G,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,wBAAwB,EACpB,sHAAsH;SAC7H;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,yCAAyC;CAClD,CAAC,CAAC;AAEP,eAAe,uCAAuC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-mcp-servers.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-mcp-servers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAkC7E,QAAA,MAAM,+BAA+B,EAAE,iBAwDrC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `require-valid-agent-mcp-servers`.
|
|
4
|
+
*/
|
|
5
|
+
import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterList, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const formatMcpServersValue = (scalarValue, listValue) => {
|
|
10
|
+
if (scalarValue !== undefined) {
|
|
11
|
+
return scalarValue;
|
|
12
|
+
}
|
|
13
|
+
if (listValue !== undefined) {
|
|
14
|
+
return `[${listValue.join(", ")}]`;
|
|
15
|
+
}
|
|
16
|
+
return "(empty)";
|
|
17
|
+
};
|
|
18
|
+
const requireValidAgentMcpServersRule = createCopilotRule({
|
|
19
|
+
create(context) {
|
|
20
|
+
return createMarkdownDocumentListener(() => {
|
|
21
|
+
if (!isCustomAgentFilePath(context.filename)) {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
25
|
+
if (frontmatter === null ||
|
|
26
|
+
!hasFrontmatterField(frontmatter, "mcp-servers")) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
const mcpServers = getFrontmatterList(frontmatter, "mcp-servers");
|
|
30
|
+
if (mcpServers !== undefined && mcpServers.length > 0) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
reportAtDocumentStart(context, {
|
|
34
|
+
data: {
|
|
35
|
+
mcpServersValue: formatMcpServersValue(getFrontmatterScalar(frontmatter, "mcp-servers"), mcpServers),
|
|
36
|
+
},
|
|
37
|
+
messageId: "invalidMcpServersField",
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
},
|
|
41
|
+
defaultOptions: [],
|
|
42
|
+
meta: {
|
|
43
|
+
deprecated: false,
|
|
44
|
+
docs: {
|
|
45
|
+
copilotConfigs: [
|
|
46
|
+
"copilot.configs.recommended",
|
|
47
|
+
"copilot.configs.strict",
|
|
48
|
+
"copilot.configs.all",
|
|
49
|
+
],
|
|
50
|
+
description: "require Copilot custom-agent `mcp-servers` metadata to be a non-empty list when present.",
|
|
51
|
+
frozen: false,
|
|
52
|
+
recommended: true,
|
|
53
|
+
requiresTypeChecking: false,
|
|
54
|
+
},
|
|
55
|
+
messages: {
|
|
56
|
+
invalidMcpServersField: "Copilot custom agent `mcp-servers` metadata must be a non-empty list of MCP server config names (current value: `{{mcpServersValue}}`).",
|
|
57
|
+
},
|
|
58
|
+
schema: [],
|
|
59
|
+
type: "problem",
|
|
60
|
+
},
|
|
61
|
+
name: "require-valid-agent-mcp-servers",
|
|
62
|
+
});
|
|
63
|
+
export default requireValidAgentMcpServersRule;
|
|
64
|
+
//# sourceMappingURL=require-valid-agent-mcp-servers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-mcp-servers.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-mcp-servers.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,GACtB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,qBAAqB,GAAG,CAC1B,WAA+B,EAC/B,SAAwC,EAClC,EAAE;IACR,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;QAC5B,OAAO,WAAW,CAAC;IACvB,CAAC;IAED,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;QAC1B,OAAO,IAAI,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;IACvC,CAAC;IAED,OAAO,SAAS,CAAC;AACrB,CAAC,CAAC;AAEF,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;YAEhE,IACI,WAAW,KAAK,IAAI;gBACpB,CAAC,mBAAmB,CAAC,WAAW,EAAE,aAAa,CAAC,EAClD,CAAC;gBACC,OAAO;YACX,CAAC;YAED,MAAM,UAAU,GAAG,kBAAkB,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;YAElE,IAAI,UAAU,KAAK,SAAS,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACpD,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,eAAe,EAAE,qBAAqB,CAClC,oBAAoB,CAAC,WAAW,EAAE,aAAa,CAAC,EAChD,UAAU,CACb;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,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,0FAA0F;YAC9F,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,sBAAsB,EAClB,yIAAyI;SAChJ;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":"require-valid-agent-model.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-model.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAqB7E,QAAA,MAAM,0BAA0B,EAAE,iBAkEhC,CAAC;AAEH,eAAe,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* ESLint rule implementation for `require-valid-agent-model`.
|
|
4
|
+
*/
|
|
5
|
+
import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
6
|
+
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
|
+
import { extractFrontmatter, getFrontmatterList, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
|
|
8
|
+
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
9
|
+
const INLINE_LIST_LITERAL_PATTERN = /^\s*\[.*\]\s*$/u;
|
|
10
|
+
const requireValidAgentModelRule = createCopilotRule({
|
|
11
|
+
create(context) {
|
|
12
|
+
return createMarkdownDocumentListener(() => {
|
|
13
|
+
if (!isCustomAgentFilePath(context.filename)) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const frontmatter = extractFrontmatter(context.sourceCode.text);
|
|
17
|
+
if (frontmatter === null ||
|
|
18
|
+
!hasFrontmatterField(frontmatter, "model")) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const modelList = getFrontmatterList(frontmatter, "model");
|
|
22
|
+
if (modelList !== undefined && modelList.length > 0) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const model = getFrontmatterScalar(frontmatter, "model");
|
|
26
|
+
if (model !== undefined &&
|
|
27
|
+
model.length > 0 &&
|
|
28
|
+
!INLINE_LIST_LITERAL_PATTERN.test(model)) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
reportAtDocumentStart(context, {
|
|
32
|
+
data: {
|
|
33
|
+
modelValue: model === undefined || model.trim().length === 0
|
|
34
|
+
? "(empty)"
|
|
35
|
+
: model,
|
|
36
|
+
},
|
|
37
|
+
messageId: "invalidAgentModel",
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
},
|
|
41
|
+
defaultOptions: [],
|
|
42
|
+
meta: {
|
|
43
|
+
deprecated: false,
|
|
44
|
+
docs: {
|
|
45
|
+
copilotConfigs: [
|
|
46
|
+
"copilot.configs.recommended",
|
|
47
|
+
"copilot.configs.strict",
|
|
48
|
+
"copilot.configs.all",
|
|
49
|
+
],
|
|
50
|
+
description: "require Copilot custom-agent `model` metadata to be a non-empty model name or non-empty prioritized model list when present.",
|
|
51
|
+
frozen: false,
|
|
52
|
+
recommended: true,
|
|
53
|
+
requiresTypeChecking: false,
|
|
54
|
+
},
|
|
55
|
+
messages: {
|
|
56
|
+
invalidAgentModel: "Copilot custom agent `model` must be a non-empty model name or non-empty prioritized list of model names (current value: `{{modelValue}}`).",
|
|
57
|
+
},
|
|
58
|
+
schema: [],
|
|
59
|
+
type: "problem",
|
|
60
|
+
},
|
|
61
|
+
name: "require-valid-agent-model",
|
|
62
|
+
});
|
|
63
|
+
export default requireValidAgentModelRule;
|
|
64
|
+
//# sourceMappingURL=require-valid-agent-model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"require-valid-agent-model.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-model.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,GACtB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AAEvC,MAAM,2BAA2B,GAAG,iBAAiB,CAAC;AAEtD,MAAM,0BAA0B,GAAsB,iBAAiB,CAAC;IACpE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IACI,WAAW,KAAK,IAAI;gBACpB,CAAC,mBAAmB,CAAC,WAAW,EAAE,OAAO,CAAC,EAC5C,CAAC;gBACC,OAAO;YACX,CAAC;YAED,MAAM,SAAS,GAAG,kBAAkB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAE3D,IAAI,SAAS,KAAK,SAAS,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAClD,OAAO;YACX,CAAC;YAED,MAAM,KAAK,GAAG,oBAAoB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;YAEzD,IACI,KAAK,KAAK,SAAS;gBACnB,KAAK,CAAC,MAAM,GAAG,CAAC;gBAChB,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,EAC1C,CAAC;gBACC,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,UAAU,EACN,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC;wBAC5C,CAAC,CAAC,SAAS;wBACX,CAAC,CAAC,KAAK;iBAClB;gBACD,SAAS,EAAE,mBAAmB;aACjC,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,8HAA8H;YAClI,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;SAC9B;QACD,QAAQ,EAAE;YACN,iBAAiB,EACb,6IAA6I;SACpJ;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":"require-valid-agent-name.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-name.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAkB7E,QAAA,MAAM,yBAAyB,EAAE,iBAgD/B,CAAC;AAEH,eAAe,yBAAyB,CAAC"}
|