eslint-plugin-copilot 1.0.8 → 1.1.0
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/dist/_internal/copilot-config-references.d.ts +1 -1
- package/dist/_internal/copilot-config-references.d.ts.map +1 -1
- package/dist/_internal/copilot-config-references.js +3 -1
- package/dist/_internal/copilot-config-references.js.map +1 -1
- package/dist/_internal/copilot-file-kind.d.ts.map +1 -1
- package/dist/_internal/copilot-file-kind.js +4 -3
- package/dist/_internal/copilot-file-kind.js.map +1 -1
- package/dist/_internal/create-copilot-rule.d.ts +4 -2
- package/dist/_internal/create-copilot-rule.d.ts.map +1 -1
- package/dist/_internal/create-copilot-rule.js.map +1 -1
- package/dist/_internal/file-system.d.ts.map +1 -1
- package/dist/_internal/file-system.js +31 -18
- package/dist/_internal/file-system.js.map +1 -1
- package/dist/_internal/frontmatter.d.ts +1 -1
- package/dist/_internal/frontmatter.d.ts.map +1 -1
- package/dist/_internal/frontmatter.js +151 -119
- package/dist/_internal/frontmatter.js.map +1 -1
- package/dist/_internal/markdown-links.d.ts.map +1 -1
- package/dist/_internal/markdown-links.js +3 -1
- package/dist/_internal/markdown-links.js.map +1 -1
- package/dist/_internal/markdown-rule.d.ts +2 -1
- package/dist/_internal/markdown-rule.d.ts.map +1 -1
- package/dist/_internal/markdown-rule.js.map +1 -1
- package/dist/_internal/repository-hooks-json.d.ts +5 -2
- package/dist/_internal/repository-hooks-json.d.ts.map +1 -1
- package/dist/_internal/repository-hooks-json.js +7 -6
- package/dist/_internal/repository-hooks-json.js.map +1 -1
- package/dist/_internal/rule-catalog.d.ts.map +1 -1
- package/dist/_internal/rule-catalog.js +2 -3
- package/dist/_internal/rule-catalog.js.map +1 -1
- package/dist/plugin.cjs +588 -409
- package/dist/plugin.cjs.map +4 -4
- package/dist/plugin.d.cts +2 -1
- package/dist/plugin.d.ts +2 -1
- package/dist/plugin.d.ts.map +1 -1
- package/dist/plugin.js +4 -3
- package/dist/plugin.js.map +1 -1
- package/dist/rules/no-blank-customization-body.d.ts +1 -0
- package/dist/rules/no-blank-customization-body.d.ts.map +1 -1
- package/dist/rules/no-blank-customization-body.js +3 -0
- package/dist/rules/no-blank-customization-body.js.map +1 -1
- package/dist/rules/no-blank-repository-instructions.d.ts +1 -0
- package/dist/rules/no-blank-repository-instructions.d.ts.map +1 -1
- package/dist/rules/no-blank-repository-instructions.js +3 -0
- package/dist/rules/no-blank-repository-instructions.js.map +1 -1
- package/dist/rules/no-blank-skill-body.d.ts +1 -0
- package/dist/rules/no-blank-skill-body.d.ts.map +1 -1
- package/dist/rules/no-blank-skill-body.js +3 -0
- package/dist/rules/no-blank-skill-body.js.map +1 -1
- package/dist/rules/no-deprecated-agent-infer.d.ts +1 -0
- package/dist/rules/no-deprecated-agent-infer.d.ts.map +1 -1
- package/dist/rules/no-deprecated-agent-infer.js +3 -0
- package/dist/rules/no-deprecated-agent-infer.js.map +1 -1
- package/dist/rules/no-duplicate-agent-names.d.ts +1 -0
- package/dist/rules/no-duplicate-agent-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-agent-names.js +6 -4
- package/dist/rules/no-duplicate-agent-names.js.map +1 -1
- package/dist/rules/no-duplicate-prompt-names.d.ts +1 -0
- package/dist/rules/no-duplicate-prompt-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-prompt-names.js +6 -4
- package/dist/rules/no-duplicate-prompt-names.js.map +1 -1
- package/dist/rules/no-duplicate-skill-names.d.ts +1 -0
- package/dist/rules/no-duplicate-skill-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-skill-names.js +6 -4
- package/dist/rules/no-duplicate-skill-names.js.map +1 -1
- package/dist/rules/no-duplicate-slash-command-names.d.ts +1 -0
- package/dist/rules/no-duplicate-slash-command-names.d.ts.map +1 -1
- package/dist/rules/no-duplicate-slash-command-names.js +6 -4
- package/dist/rules/no-duplicate-slash-command-names.js.map +1 -1
- package/dist/rules/no-empty-repository-hook-arrays.d.ts +1 -0
- package/dist/rules/no-empty-repository-hook-arrays.d.ts.map +1 -1
- package/dist/rules/no-empty-repository-hook-arrays.js +7 -3
- package/dist/rules/no-empty-repository-hook-arrays.js.map +1 -1
- package/dist/rules/no-legacy-chatmode-files.d.ts +1 -0
- package/dist/rules/no-legacy-chatmode-files.d.ts.map +1 -1
- package/dist/rules/no-legacy-chatmode-files.js +3 -0
- package/dist/rules/no-legacy-chatmode-files.js.map +1 -1
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts +1 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.d.ts.map +1 -1
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.js +3 -0
- package/dist/rules/prefer-custom-instructions-under-code-review-limit.js.map +1 -1
- package/dist/rules/prefer-fast-repository-hooks.d.ts +1 -0
- package/dist/rules/prefer-fast-repository-hooks.d.ts.map +1 -1
- package/dist/rules/prefer-fast-repository-hooks.js +5 -1
- package/dist/rules/prefer-fast-repository-hooks.js.map +1 -1
- package/dist/rules/prefer-qualified-tools.d.ts +1 -0
- package/dist/rules/prefer-qualified-tools.d.ts.map +1 -1
- package/dist/rules/prefer-qualified-tools.js +8 -3
- package/dist/rules/prefer-qualified-tools.js.map +1 -1
- package/dist/rules/require-agent-tool-for-subagents.d.ts +1 -0
- package/dist/rules/require-agent-tool-for-subagents.d.ts.map +1 -1
- package/dist/rules/require-agent-tool-for-subagents.js +6 -2
- package/dist/rules/require-agent-tool-for-subagents.js.map +1 -1
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts +1 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.d.ts.map +1 -1
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js +3 -0
- package/dist/rules/require-agents-md-for-cross-surface-agent-instructions.js.map +1 -1
- package/dist/rules/require-chatmode-file-metadata.d.ts +1 -0
- package/dist/rules/require-chatmode-file-metadata.d.ts.map +1 -1
- package/dist/rules/require-chatmode-file-metadata.js +5 -1
- package/dist/rules/require-chatmode-file-metadata.js.map +1 -1
- package/dist/rules/require-existing-agent-hook-cwd.d.ts +1 -0
- package/dist/rules/require-existing-agent-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-existing-agent-hook-cwd.js +6 -2
- package/dist/rules/require-existing-agent-hook-cwd.js.map +1 -1
- package/dist/rules/require-existing-agent-mcp-servers.d.ts +1 -0
- package/dist/rules/require-existing-agent-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-existing-agent-mcp-servers.js +6 -2
- package/dist/rules/require-existing-agent-mcp-servers.js.map +1 -1
- package/dist/rules/require-existing-relative-agent-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-agent-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-agent-links.js +3 -0
- package/dist/rules/require-existing-relative-agent-links.js.map +1 -1
- package/dist/rules/require-existing-relative-instructions-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-instructions-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-instructions-links.js +3 -0
- package/dist/rules/require-existing-relative-instructions-links.js.map +1 -1
- package/dist/rules/require-existing-relative-prompt-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-prompt-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-prompt-links.js +3 -0
- package/dist/rules/require-existing-relative-prompt-links.js.map +1 -1
- package/dist/rules/require-existing-relative-skill-links.d.ts +1 -0
- package/dist/rules/require-existing-relative-skill-links.d.ts.map +1 -1
- package/dist/rules/require-existing-relative-skill-links.js +3 -0
- package/dist/rules/require-existing-relative-skill-links.js.map +1 -1
- package/dist/rules/require-existing-repository-hook-cwd.d.ts +1 -0
- package/dist/rules/require-existing-repository-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-existing-repository-hook-cwd.js +5 -1
- package/dist/rules/require-existing-repository-hook-cwd.js.map +1 -1
- package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts +1 -0
- package/dist/rules/require-github-copilot-target-for-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-github-copilot-target-for-mcp-servers.js +5 -1
- package/dist/rules/require-github-copilot-target-for-mcp-servers.js.map +1 -1
- package/dist/rules/require-instructions-apply-to.d.ts +1 -0
- package/dist/rules/require-instructions-apply-to.d.ts.map +1 -1
- package/dist/rules/require-instructions-apply-to.js +5 -1
- package/dist/rules/require-instructions-apply-to.js.map +1 -1
- package/dist/rules/require-json-agent-mcp-servers.d.ts +1 -0
- package/dist/rules/require-json-agent-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-json-agent-mcp-servers.js +6 -2
- package/dist/rules/require-json-agent-mcp-servers.js.map +1 -1
- package/dist/rules/require-prompt-file-metadata.d.ts +1 -0
- package/dist/rules/require-prompt-file-metadata.d.ts.map +1 -1
- package/dist/rules/require-prompt-file-metadata.js +43 -32
- package/dist/rules/require-prompt-file-metadata.js.map +1 -1
- package/dist/rules/require-qualified-agent-handoff-models.d.ts +1 -0
- package/dist/rules/require-qualified-agent-handoff-models.d.ts.map +1 -1
- package/dist/rules/require-qualified-agent-handoff-models.js +6 -2
- package/dist/rules/require-qualified-agent-handoff-models.js.map +1 -1
- package/dist/rules/require-relative-agent-hook-cwd.d.ts +1 -0
- package/dist/rules/require-relative-agent-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-relative-agent-hook-cwd.js +6 -2
- package/dist/rules/require-relative-agent-hook-cwd.js.map +1 -1
- package/dist/rules/require-relative-agent-links.d.ts +1 -0
- package/dist/rules/require-relative-agent-links.d.ts.map +1 -1
- package/dist/rules/require-relative-agent-links.js +3 -0
- package/dist/rules/require-relative-agent-links.js.map +1 -1
- package/dist/rules/require-relative-instructions-links.d.ts +1 -0
- package/dist/rules/require-relative-instructions-links.d.ts.map +1 -1
- package/dist/rules/require-relative-instructions-links.js +3 -0
- package/dist/rules/require-relative-instructions-links.js.map +1 -1
- package/dist/rules/require-relative-prompt-links.d.ts +1 -0
- package/dist/rules/require-relative-prompt-links.d.ts.map +1 -1
- package/dist/rules/require-relative-prompt-links.js +3 -0
- package/dist/rules/require-relative-prompt-links.js.map +1 -1
- package/dist/rules/require-relative-repository-hook-cwd.d.ts +1 -0
- package/dist/rules/require-relative-repository-hook-cwd.d.ts.map +1 -1
- package/dist/rules/require-relative-repository-hook-cwd.js +5 -1
- package/dist/rules/require-relative-repository-hook-cwd.js.map +1 -1
- package/dist/rules/require-relative-skill-links.d.ts +1 -0
- package/dist/rules/require-relative-skill-links.d.ts.map +1 -1
- package/dist/rules/require-relative-skill-links.js +3 -0
- package/dist/rules/require-relative-skill-links.js.map +1 -1
- package/dist/rules/require-repository-hook-arrays.d.ts +1 -0
- package/dist/rules/require-repository-hook-arrays.d.ts.map +1 -1
- package/dist/rules/require-repository-hook-arrays.js +7 -3
- package/dist/rules/require-repository-hook-arrays.js.map +1 -1
- package/dist/rules/require-repository-hook-command-shell.d.ts +1 -0
- package/dist/rules/require-repository-hook-command-shell.d.ts.map +1 -1
- package/dist/rules/require-repository-hook-command-shell.js +5 -1
- package/dist/rules/require-repository-hook-command-shell.js.map +1 -1
- package/dist/rules/require-repository-hooks-object.d.ts +1 -0
- package/dist/rules/require-repository-hooks-object.d.ts.map +1 -1
- package/dist/rules/require-repository-hooks-object.js +3 -0
- package/dist/rules/require-repository-hooks-object.js.map +1 -1
- package/dist/rules/require-repository-instructions-file.d.ts +1 -0
- package/dist/rules/require-repository-instructions-file.d.ts.map +1 -1
- package/dist/rules/require-repository-instructions-file.js +3 -0
- package/dist/rules/require-repository-instructions-file.js.map +1 -1
- package/dist/rules/require-skill-file-location.d.ts +1 -0
- package/dist/rules/require-skill-file-location.d.ts.map +1 -1
- package/dist/rules/require-skill-file-location.js +3 -0
- package/dist/rules/require-skill-file-location.js.map +1 -1
- package/dist/rules/require-skill-file-metadata.d.ts +1 -0
- package/dist/rules/require-skill-file-metadata.d.ts.map +1 -1
- package/dist/rules/require-skill-file-metadata.js +6 -2
- package/dist/rules/require-skill-file-metadata.js.map +1 -1
- package/dist/rules/require-skill-md-filename.d.ts +1 -0
- package/dist/rules/require-skill-md-filename.d.ts.map +1 -1
- package/dist/rules/require-skill-md-filename.js +3 -0
- package/dist/rules/require-skill-md-filename.js.map +1 -1
- package/dist/rules/require-skill-name-match-directory.d.ts +1 -0
- package/dist/rules/require-skill-name-match-directory.d.ts.map +1 -1
- package/dist/rules/require-skill-name-match-directory.js +5 -1
- package/dist/rules/require-skill-name-match-directory.js.map +1 -1
- package/dist/rules/require-string-repository-hook-env-values.d.ts +1 -0
- package/dist/rules/require-string-repository-hook-env-values.d.ts.map +1 -1
- package/dist/rules/require-string-repository-hook-env-values.js +6 -2
- package/dist/rules/require-string-repository-hook-env-values.js.map +1 -1
- package/dist/rules/require-valid-agent-argument-hint.d.ts +1 -0
- package/dist/rules/require-valid-agent-argument-hint.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-argument-hint.js +5 -1
- package/dist/rules/require-valid-agent-argument-hint.js.map +1 -1
- package/dist/rules/require-valid-agent-handoff-send.d.ts +1 -0
- package/dist/rules/require-valid-agent-handoff-send.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-handoff-send.js +7 -3
- package/dist/rules/require-valid-agent-handoff-send.js.map +1 -1
- package/dist/rules/require-valid-agent-handoffs.d.ts +1 -0
- package/dist/rules/require-valid-agent-handoffs.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-handoffs.js +5 -1
- package/dist/rules/require-valid-agent-handoffs.js.map +1 -1
- package/dist/rules/require-valid-agent-hook-events.d.ts +1 -0
- package/dist/rules/require-valid-agent-hook-events.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-hook-events.js +6 -2
- package/dist/rules/require-valid-agent-hook-events.js.map +1 -1
- package/dist/rules/require-valid-agent-hook-timeouts.d.ts +1 -0
- package/dist/rules/require-valid-agent-hook-timeouts.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-hook-timeouts.js +6 -2
- package/dist/rules/require-valid-agent-hook-timeouts.js.map +1 -1
- package/dist/rules/require-valid-agent-hooks.d.ts +1 -0
- package/dist/rules/require-valid-agent-hooks.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-hooks.js +31 -21
- package/dist/rules/require-valid-agent-hooks.js.map +1 -1
- package/dist/rules/require-valid-agent-invocation-controls.d.ts +1 -0
- package/dist/rules/require-valid-agent-invocation-controls.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-invocation-controls.js +7 -3
- package/dist/rules/require-valid-agent-invocation-controls.js.map +1 -1
- package/dist/rules/require-valid-agent-mcp-servers.d.ts +1 -0
- package/dist/rules/require-valid-agent-mcp-servers.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-mcp-servers.js +8 -4
- package/dist/rules/require-valid-agent-mcp-servers.js.map +1 -1
- package/dist/rules/require-valid-agent-model.d.ts +1 -0
- package/dist/rules/require-valid-agent-model.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-model.js +7 -3
- package/dist/rules/require-valid-agent-model.js.map +1 -1
- package/dist/rules/require-valid-agent-name.d.ts +1 -0
- package/dist/rules/require-valid-agent-name.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-name.js +5 -1
- package/dist/rules/require-valid-agent-name.js.map +1 -1
- package/dist/rules/require-valid-agent-subagents.d.ts +1 -0
- package/dist/rules/require-valid-agent-subagents.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-subagents.js +8 -4
- package/dist/rules/require-valid-agent-subagents.js.map +1 -1
- package/dist/rules/require-valid-agent-target.d.ts +1 -0
- package/dist/rules/require-valid-agent-target.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-target.js +6 -2
- package/dist/rules/require-valid-agent-target.js.map +1 -1
- package/dist/rules/require-valid-agent-tools.d.ts +1 -0
- package/dist/rules/require-valid-agent-tools.d.ts.map +1 -1
- package/dist/rules/require-valid-agent-tools.js +8 -4
- package/dist/rules/require-valid-agent-tools.js.map +1 -1
- package/dist/rules/require-valid-instructions-apply-to-globs.d.ts +1 -0
- package/dist/rules/require-valid-instructions-apply-to-globs.d.ts.map +1 -1
- package/dist/rules/require-valid-instructions-apply-to-globs.js +8 -3
- package/dist/rules/require-valid-instructions-apply-to-globs.js.map +1 -1
- package/dist/rules/require-valid-prompt-argument-hint.d.ts +1 -0
- package/dist/rules/require-valid-prompt-argument-hint.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-argument-hint.js +6 -3
- package/dist/rules/require-valid-prompt-argument-hint.js.map +1 -1
- package/dist/rules/require-valid-prompt-model.d.ts +1 -0
- package/dist/rules/require-valid-prompt-model.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-model.js +9 -5
- package/dist/rules/require-valid-prompt-model.js.map +1 -1
- package/dist/rules/require-valid-prompt-name.d.ts +1 -0
- package/dist/rules/require-valid-prompt-name.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-name.js +5 -1
- package/dist/rules/require-valid-prompt-name.js.map +1 -1
- package/dist/rules/require-valid-prompt-tools.d.ts +1 -0
- package/dist/rules/require-valid-prompt-tools.d.ts.map +1 -1
- package/dist/rules/require-valid-prompt-tools.js +8 -4
- package/dist/rules/require-valid-prompt-tools.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-command-type.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-command-type.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-command-type.js +5 -1
- package/dist/rules/require-valid-repository-hook-command-type.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-env.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-env.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-env.js +6 -2
- package/dist/rules/require-valid-repository-hook-env.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-events.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-events.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-events.js +5 -1
- package/dist/rules/require-valid-repository-hook-events.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-timeouts.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-timeouts.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-timeouts.js +7 -3
- package/dist/rules/require-valid-repository-hook-timeouts.js.map +1 -1
- package/dist/rules/require-valid-repository-hook-version.d.ts +1 -0
- package/dist/rules/require-valid-repository-hook-version.d.ts.map +1 -1
- package/dist/rules/require-valid-repository-hook-version.js +3 -0
- package/dist/rules/require-valid-repository-hook-version.js.map +1 -1
- package/dist/rules/require-valid-skill-directory-name.d.ts +1 -0
- package/dist/rules/require-valid-skill-directory-name.d.ts.map +1 -1
- package/dist/rules/require-valid-skill-directory-name.js +3 -0
- package/dist/rules/require-valid-skill-directory-name.js.map +1 -1
- package/dist/rules/require-valid-skill-license.d.ts +1 -0
- package/dist/rules/require-valid-skill-license.d.ts.map +1 -1
- package/dist/rules/require-valid-skill-license.js +5 -1
- package/dist/rules/require-valid-skill-license.js.map +1 -1
- package/dist/rules/require-valid-skill-name.d.ts +1 -0
- package/dist/rules/require-valid-skill-name.d.ts.map +1 -1
- package/dist/rules/require-valid-skill-name.js +5 -1
- package/dist/rules/require-valid-skill-name.js.map +1 -1
- package/package.json +65 -53
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
import { getSkillDirectoryName, getSkillName, } from "../_internal/copilot-customization-names.js";
|
|
2
3
|
import { isSkillFilePath } from "../_internal/copilot-file-kind.js";
|
|
3
4
|
/**
|
|
@@ -7,6 +8,8 @@ import { isSkillFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
7
8
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
8
9
|
import { extractFrontmatter, getFrontmatterScalar, } from "../_internal/frontmatter.js";
|
|
9
10
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
11
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
12
|
+
/** Rule module for `require-skill-name-match-directory`. */
|
|
10
13
|
const requireSkillNameMatchDirectoryRule = createCopilotRule({
|
|
11
14
|
create(context) {
|
|
12
15
|
return createMarkdownDocumentListener(() => {
|
|
@@ -17,7 +20,7 @@ const requireSkillNameMatchDirectoryRule = createCopilotRule({
|
|
|
17
20
|
const explicitSkillName = frontmatter === null
|
|
18
21
|
? undefined
|
|
19
22
|
: getFrontmatterScalar(frontmatter, "name");
|
|
20
|
-
if (explicitSkillName
|
|
23
|
+
if (!isDefined(explicitSkillName)) {
|
|
21
24
|
return;
|
|
22
25
|
}
|
|
23
26
|
const skillName = getSkillName(context.filename, frontmatter);
|
|
@@ -45,6 +48,7 @@ const requireSkillNameMatchDirectoryRule = createCopilotRule({
|
|
|
45
48
|
frozen: false,
|
|
46
49
|
recommended: false,
|
|
47
50
|
requiresTypeChecking: false,
|
|
51
|
+
url: createRuleDocsUrl("require-skill-name-match-directory"),
|
|
48
52
|
},
|
|
49
53
|
messages: {
|
|
50
54
|
skillNameDoesNotMatchDirectory: "Copilot skill `name` value `{{name}}` should match its directory name `{{directoryName}}`.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-skill-name-match-directory.js","sourceRoot":"","sources":["../../src/rules/require-skill-name-match-directory.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-skill-name-match-directory.js","sourceRoot":"","sources":["../../src/rules/require-skill-name-match-directory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAItC,OAAO,EACH,qBAAqB,EACrB,YAAY,GACf,MAAM,6CAA6C,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE;;;GAGG;AACH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,oBAAoB,GACvB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,4DAA4D;AAC5D,MAAM,kCAAkC,GAAsB,iBAAiB,CAC3E;IACI,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACrC,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAChE,MAAM,iBAAiB,GACnB,WAAW,KAAK,IAAI;gBAChB,CAAC,CAAC,SAAS;gBACX,CAAC,CAAC,oBAAoB,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;YAEpD,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,EAAE,CAAC;gBAChC,OAAO;YACX,CAAC;YAED,MAAM,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;YAC9D,MAAM,aAAa,GAAG,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAE9D,IAAI,SAAS,KAAK,aAAa,EAAE,CAAC;gBAC9B,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,IAAI,EAAE;oBACF,aAAa;oBACb,IAAI,EAAE,SAAS;iBAClB;gBACD,SAAS,EAAE,gCAAgC;aAC9C,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,0EAA0E;YAC9E,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,KAAK;YAClB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,oCAAoC,CAAC;SAC/D;QACD,QAAQ,EAAE;YACN,8BAA8B,EAC1B,4FAA4F;SACnG;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,oCAAoC;CAC7C,CACJ,CAAC;AAEF,eAAe,kCAAkC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-string-repository-hook-env-values`. */
|
|
2
3
|
declare const requireStringRepositoryHookEnvValuesRule: CopilotRuleModule;
|
|
3
4
|
export default requireStringRepositoryHookEnvValuesRule;
|
|
4
5
|
//# sourceMappingURL=require-string-repository-hook-env-values.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-string-repository-hook-env-values.d.ts","sourceRoot":"","sources":["../../src/rules/require-string-repository-hook-env-values.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-string-repository-hook-env-values.d.ts","sourceRoot":"","sources":["../../src/rules/require-string-repository-hook-env-values.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAkB7E,mEAAmE;AACnE,QAAA,MAAM,wCAAwC,EAAE,iBAgE1C,CAAC;AAEP,eAAe,wCAAwC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined, objectValues } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-string-repository-hook-env-values`.
|
|
@@ -6,6 +7,8 @@ import { isRepositoryHookFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { reportAtDocumentStart } from "../_internal/markdown-rule.js";
|
|
8
9
|
import { formatJsonValue, getRepositoryHookObjects, isJsonObject, isJsonString, parseJsonText, } from "../_internal/repository-hooks-json.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
/** Rule module for `require-string-repository-hook-env-values`. */
|
|
9
12
|
const requireStringRepositoryHookEnvValuesRule = createCopilotRule({
|
|
10
13
|
create(context) {
|
|
11
14
|
return {
|
|
@@ -17,9 +20,9 @@ const requireStringRepositoryHookEnvValuesRule = createCopilotRule({
|
|
|
17
20
|
const invalidHook = getRepositoryHookObjects(root).find(({ hook }) => {
|
|
18
21
|
const env = hook["env"];
|
|
19
22
|
return (isJsonObject(env) &&
|
|
20
|
-
|
|
23
|
+
objectValues(env).some((value) => !isJsonString(value)));
|
|
21
24
|
});
|
|
22
|
-
if (invalidHook
|
|
25
|
+
if (!isDefined(invalidHook)) {
|
|
23
26
|
return;
|
|
24
27
|
}
|
|
25
28
|
const env = invalidHook.hook["env"];
|
|
@@ -45,6 +48,7 @@ const requireStringRepositoryHookEnvValuesRule = createCopilotRule({
|
|
|
45
48
|
frozen: false,
|
|
46
49
|
recommended: true,
|
|
47
50
|
requiresTypeChecking: false,
|
|
51
|
+
url: createRuleDocsUrl("require-string-repository-hook-env-values"),
|
|
48
52
|
},
|
|
49
53
|
messages: {
|
|
50
54
|
nonStringRepositoryHookEnvValue: "Repository hook `env` for `{{eventName}}` must use string values only (current value: `{{env}}`).",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-string-repository-hook-env-values.js","sourceRoot":"","sources":["../../src/rules/require-string-repository-hook-env-values.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-string-repository-hook-env-values.js","sourceRoot":"","sources":["../../src/rules/require-string-repository-hook-env-values.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAIpD;;;GAGG;AACH,OAAO,EAAE,wBAAwB,EAAE,MAAM,mCAAmC,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EACH,eAAe,EACf,wBAAwB,EACxB,YAAY,EACZ,YAAY,EACZ,aAAa,GAChB,MAAM,uCAAuC,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,mEAAmE;AACnE,MAAM,wCAAwC,GAC1C,iBAAiB,CAAC;IACd,MAAM,CAAC,OAAO;QACV,OAAO;YACH,QAAQ;gBACJ,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC9C,OAAO;gBACX,CAAC;gBAED,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACpD,MAAM,WAAW,GAAG,wBAAwB,CAAC,IAAI,CAAC,CAAC,IAAI,CACnD,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;oBACT,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;oBAExB,OAAO,CACH,YAAY,CAAC,GAAG,CAAC;wBACjB,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,CAClB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAClC,CACJ,CAAC;gBACN,CAAC,CACJ,CAAC;gBAEF,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC;oBAC1B,OAAO;gBACX,CAAC;gBAED,MAAM,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAEpC,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,GAAG,EAAE,eAAe,CAAC,GAAG,CAAC;wBACzB,SAAS,EAAE,WAAW,CAAC,SAAS;qBACnC;oBACD,SAAS,EAAE,iCAAiC;iBAC/C,CAAC,CAAC;YACP,CAAC;SACJ,CAAC;IACN,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,6DAA6D;YACjE,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAClB,2CAA2C,CAC9C;SACJ;QACD,QAAQ,EAAE;YACN,+BAA+B,EAC3B,mGAAmG;SAC1G;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,2CAA2C;CACpD,CAAC,CAAC;AAEP,eAAe,wCAAwC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-argument-hint`. */
|
|
2
3
|
declare const requireValidAgentArgumentHintRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentArgumentHintRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-argument-hint.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-argument-hint.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-argument-hint.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-argument-hint.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-argument-hint.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAmB7E,2DAA2D;AAC3D,QAAA,MAAM,iCAAiC,EAAE,iBAgDvC,CAAC;AAEH,eAAe,iCAAiC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-valid-agent-argument-hint`.
|
|
@@ -6,6 +7,8 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
/** Rule module for `require-valid-agent-argument-hint`. */
|
|
9
12
|
const requireValidAgentArgumentHintRule = createCopilotRule({
|
|
10
13
|
create(context) {
|
|
11
14
|
return createMarkdownDocumentListener(() => {
|
|
@@ -17,7 +20,7 @@ const requireValidAgentArgumentHintRule = createCopilotRule({
|
|
|
17
20
|
!hasFrontmatterField(frontmatter, "argument-hint")) {
|
|
18
21
|
return;
|
|
19
22
|
}
|
|
20
|
-
if (getFrontmatterScalar(frontmatter, "argument-hint")
|
|
23
|
+
if (isDefined(getFrontmatterScalar(frontmatter, "argument-hint"))) {
|
|
21
24
|
return;
|
|
22
25
|
}
|
|
23
26
|
reportAtDocumentStart(context, {
|
|
@@ -37,6 +40,7 @@ const requireValidAgentArgumentHintRule = createCopilotRule({
|
|
|
37
40
|
frozen: false,
|
|
38
41
|
recommended: true,
|
|
39
42
|
requiresTypeChecking: false,
|
|
43
|
+
url: createRuleDocsUrl("require-valid-agent-argument-hint"),
|
|
40
44
|
},
|
|
41
45
|
messages: {
|
|
42
46
|
invalidAgentArgumentHint: "Copilot custom-agent `argument-hint` metadata must be a non-empty scalar when present.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-argument-hint.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-argument-hint.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-argument-hint.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-argument-hint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAItC;;;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;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,2DAA2D;AAC3D,MAAM,iCAAiC,GAAsB,iBAAiB,CAAC;IAC3E,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IACI,WAAW,KAAK,IAAI;gBACpB,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,EACpD,CAAC;gBACC,OAAO;YACX,CAAC;YAED,IAAI,SAAS,CAAC,oBAAoB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC,EAAE,CAAC;gBAChE,OAAO;YACX,CAAC;YAED,qBAAqB,CAAC,OAAO,EAAE;gBAC3B,SAAS,EAAE,0BAA0B;aACxC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,8FAA8F;YAClG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,mCAAmC,CAAC;SAC9D;QACD,QAAQ,EAAE;YACN,wBAAwB,EACpB,wFAAwF;SAC/F;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,mCAAmC;CAC5C,CAAC,CAAC;AAEH,eAAe,iCAAiC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-handoff-send`. */
|
|
2
3
|
declare const requireValidAgentHandoffSendRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentHandoffSendRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-handoff-send.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-handoff-send.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoff-send.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-handoff-send.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoff-send.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAoB7E,0DAA0D;AAC1D,QAAA,MAAM,gCAAgC,EAAE,iBAoEtC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined, isEmpty, setHas } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-valid-agent-handoff-send`.
|
|
@@ -6,7 +7,9 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterObjectList, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
9
11
|
const VALID_BOOLEAN_FIELD_VALUES = new Set(["false", "true"]);
|
|
12
|
+
/** Rule module for `require-valid-agent-handoff-send`. */
|
|
10
13
|
const requireValidAgentHandoffSendRule = createCopilotRule({
|
|
11
14
|
create(context) {
|
|
12
15
|
return createMarkdownDocumentListener(() => {
|
|
@@ -18,16 +21,16 @@ const requireValidAgentHandoffSendRule = createCopilotRule({
|
|
|
18
21
|
return;
|
|
19
22
|
}
|
|
20
23
|
const handoffs = getFrontmatterObjectList(frontmatter, "handoffs");
|
|
21
|
-
if (handoffs
|
|
24
|
+
if (!isDefined(handoffs) || isEmpty(handoffs)) {
|
|
22
25
|
return;
|
|
23
26
|
}
|
|
24
27
|
for (const [index, handoff] of handoffs.entries()) {
|
|
25
28
|
const rawSend = handoff["send"];
|
|
26
|
-
if (rawSend
|
|
29
|
+
if (!isDefined(rawSend)) {
|
|
27
30
|
continue;
|
|
28
31
|
}
|
|
29
32
|
const normalizedSend = rawSend.trim().toLowerCase();
|
|
30
|
-
if (VALID_BOOLEAN_FIELD_VALUES
|
|
33
|
+
if (setHas(VALID_BOOLEAN_FIELD_VALUES, normalizedSend)) {
|
|
31
34
|
continue;
|
|
32
35
|
}
|
|
33
36
|
reportAtDocumentStart(context, {
|
|
@@ -53,6 +56,7 @@ const requireValidAgentHandoffSendRule = createCopilotRule({
|
|
|
53
56
|
frozen: false,
|
|
54
57
|
recommended: true,
|
|
55
58
|
requiresTypeChecking: false,
|
|
59
|
+
url: createRuleDocsUrl("require-valid-agent-handoff-send"),
|
|
56
60
|
},
|
|
57
61
|
messages: {
|
|
58
62
|
invalidHandoffSend: "Copilot custom agent handoff #{{handoffNumber}} must use a boolean `send` value (`true` or `false`), not `{{sendValue}}`.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-handoff-send.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoff-send.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-handoff-send.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoff-send.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAIvD;;;GAGG;AACH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EACH,kBAAkB,EAClB,wBAAwB,GAC3B,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACH,8BAA8B,EAC9B,qBAAqB,GACxB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,MAAM,0BAA0B,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;AAE9D,0DAA0D;AAC1D,MAAM,gCAAgC,GAAsB,iBAAiB,CAAC;IAC1E,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;gBACvB,OAAO;YACX,CAAC;YAED,MAAM,QAAQ,GAAG,wBAAwB,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;YAEnE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC5C,OAAO;YACX,CAAC;YAED,KAAK,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC;gBAChD,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;gBAEhC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;oBACtB,SAAS;gBACb,CAAC;gBAED,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBAEpD,IAAI,MAAM,CAAC,0BAA0B,EAAE,cAAc,CAAC,EAAE,CAAC;oBACrD,SAAS;gBACb,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,aAAa,EAAE,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;wBAChC,SAAS,EACL,OAAO,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;qBACtD;oBACD,SAAS,EAAE,oBAAoB;iBAClC,CAAC,CAAC;gBAEH,OAAO;YACX,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IACD,IAAI,EAAE;QACF,UAAU,EAAE,KAAK;QACjB,IAAI,EAAE;YACF,cAAc,EAAE;gBACZ,6BAA6B;gBAC7B,wBAAwB;gBACxB,qBAAqB;aACxB;YACD,WAAW,EACP,qGAAqG;YACzG,MAAM,EAAE,KAAK;YACb,WAAW,EAAE,IAAI;YACjB,oBAAoB,EAAE,KAAK;YAC3B,GAAG,EAAE,iBAAiB,CAAC,kCAAkC,CAAC;SAC7D;QACD,QAAQ,EAAE;YACN,kBAAkB,EACd,2HAA2H;SAClI;QACD,MAAM,EAAE,EAAE;QACV,IAAI,EAAE,SAAS;KAClB;IACD,IAAI,EAAE,kCAAkC;CAC3C,CAAC,CAAC;AAEH,eAAe,gCAAgC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-handoffs`. */
|
|
2
3
|
declare const requireValidAgentHandoffsRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentHandoffsRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-handoffs.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-handoffs.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoffs.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-handoffs.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoffs.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAkB7E,sDAAsD;AACtD,QAAA,MAAM,6BAA6B,EAAE,iBAkFnC,CAAC;AAEH,eAAe,6BAA6B,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined, isEmpty } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-valid-agent-handoffs`.
|
|
@@ -6,6 +7,8 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterObjectList, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
11
|
+
/** Rule module for `require-valid-agent-handoffs`. */
|
|
9
12
|
const requireValidAgentHandoffsRule = createCopilotRule({
|
|
10
13
|
create(context) {
|
|
11
14
|
return createMarkdownDocumentListener(() => {
|
|
@@ -17,7 +20,7 @@ const requireValidAgentHandoffsRule = createCopilotRule({
|
|
|
17
20
|
return;
|
|
18
21
|
}
|
|
19
22
|
const handoffs = getFrontmatterObjectList(frontmatter, "handoffs");
|
|
20
|
-
if (handoffs
|
|
23
|
+
if (!isDefined(handoffs) || isEmpty(handoffs)) {
|
|
21
24
|
return;
|
|
22
25
|
}
|
|
23
26
|
for (const [index, handoff] of handoffs.entries()) {
|
|
@@ -62,6 +65,7 @@ const requireValidAgentHandoffsRule = createCopilotRule({
|
|
|
62
65
|
frozen: false,
|
|
63
66
|
recommended: true,
|
|
64
67
|
requiresTypeChecking: false,
|
|
68
|
+
url: createRuleDocsUrl("require-valid-agent-handoffs"),
|
|
65
69
|
},
|
|
66
70
|
messages: {
|
|
67
71
|
missingAgent: "Copilot custom agent handoff #{{handoffNumber}} must define a non-empty `agent` target.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-handoffs.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoffs.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-handoffs.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-handoffs.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-hook-events`. */
|
|
2
3
|
declare const requireValidAgentHookEventsRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentHookEventsRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-hook-events.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-hook-events.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-events.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hook-events.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-events.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AA6B7E,yDAAyD;AACzD,QAAA,MAAM,+BAA+B,EAAE,iBA2DrC,CAAC;AAEH,eAAe,+BAA+B,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined, setHas } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-valid-agent-hook-events`.
|
|
@@ -6,6 +7,7 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterObjectListGroups, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
9
11
|
const VALID_HOOK_EVENT_NAMES = new Set([
|
|
10
12
|
"PostToolUse",
|
|
11
13
|
"PreCompact",
|
|
@@ -16,6 +18,7 @@ const VALID_HOOK_EVENT_NAMES = new Set([
|
|
|
16
18
|
"SubagentStop",
|
|
17
19
|
"UserPromptSubmit",
|
|
18
20
|
]);
|
|
21
|
+
/** Rule module for `require-valid-agent-hook-events`. */
|
|
19
22
|
const requireValidAgentHookEventsRule = createCopilotRule({
|
|
20
23
|
create(context) {
|
|
21
24
|
return createMarkdownDocumentListener(() => {
|
|
@@ -27,11 +30,11 @@ const requireValidAgentHookEventsRule = createCopilotRule({
|
|
|
27
30
|
return;
|
|
28
31
|
}
|
|
29
32
|
const hookGroups = getFrontmatterObjectListGroups(frontmatter, "hooks");
|
|
30
|
-
if (hookGroups
|
|
33
|
+
if (!isDefined(hookGroups) || hookGroups.size === 0) {
|
|
31
34
|
return;
|
|
32
35
|
}
|
|
33
36
|
for (const eventName of hookGroups.keys()) {
|
|
34
|
-
if (VALID_HOOK_EVENT_NAMES
|
|
37
|
+
if (setHas(VALID_HOOK_EVENT_NAMES, eventName)) {
|
|
35
38
|
continue;
|
|
36
39
|
}
|
|
37
40
|
reportAtDocumentStart(context, {
|
|
@@ -54,6 +57,7 @@ const requireValidAgentHookEventsRule = createCopilotRule({
|
|
|
54
57
|
frozen: false,
|
|
55
58
|
recommended: true,
|
|
56
59
|
requiresTypeChecking: false,
|
|
60
|
+
url: createRuleDocsUrl("require-valid-agent-hook-events"),
|
|
57
61
|
},
|
|
58
62
|
messages: {
|
|
59
63
|
invalidHookEvent: "Copilot custom agent hooks should use a supported event name, not `{{eventName}}`.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-hook-events.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-events.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hook-events.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-events.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAI9C;;;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;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,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,yDAAyD;AACzD,MAAM,+BAA+B,GAAsB,iBAAiB,CAAC;IACzE,MAAM,CAAC,OAAO;QACV,OAAO,8BAA8B,CAAC,GAAG,EAAE;YACvC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC3C,OAAO;YACX,CAAC;YAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEhE,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;gBACvB,OAAO;YACX,CAAC;YAED,MAAM,UAAU,GAAG,8BAA8B,CAC7C,WAAW,EACX,OAAO,CACV,CAAC;YAEF,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,UAAU,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;gBAClD,OAAO;YACX,CAAC;YAED,KAAK,MAAM,SAAS,IAAI,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC;gBACxC,IAAI,MAAM,CAAC,sBAAsB,EAAE,SAAS,CAAC,EAAE,CAAC;oBAC5C,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,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;YAC3B,GAAG,EAAE,iBAAiB,CAAC,iCAAiC,CAAC;SAC5D;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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-hook-timeouts`. */
|
|
2
3
|
declare const requireValidAgentHookTimeoutsRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentHookTimeoutsRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-hook-timeouts.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-hook-timeouts.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-timeouts.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hook-timeouts.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-timeouts.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAwC7E,2DAA2D;AAC3D,QAAA,MAAM,iCAAiC,EAAE,iBAuEvC,CAAC;AAEH,eAAe,iCAAiC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-valid-agent-hook-timeouts`.
|
|
@@ -6,6 +7,7 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterObjectListGroups, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
9
11
|
const isNumericTimeoutValue = (value) => {
|
|
10
12
|
let decimalPointCount = 0;
|
|
11
13
|
for (const character of value) {
|
|
@@ -22,6 +24,7 @@ const isNumericTimeoutValue = (value) => {
|
|
|
22
24
|
}
|
|
23
25
|
return value.length > 0 && !value.startsWith(".") && !value.endsWith(".");
|
|
24
26
|
};
|
|
27
|
+
/** Rule module for `require-valid-agent-hook-timeouts`. */
|
|
25
28
|
const requireValidAgentHookTimeoutsRule = createCopilotRule({
|
|
26
29
|
create(context) {
|
|
27
30
|
return createMarkdownDocumentListener(() => {
|
|
@@ -33,13 +36,13 @@ const requireValidAgentHookTimeoutsRule = createCopilotRule({
|
|
|
33
36
|
return;
|
|
34
37
|
}
|
|
35
38
|
const hookGroups = getFrontmatterObjectListGroups(frontmatter, "hooks");
|
|
36
|
-
if (hookGroups
|
|
39
|
+
if (!isDefined(hookGroups) || hookGroups.size === 0) {
|
|
37
40
|
return;
|
|
38
41
|
}
|
|
39
42
|
for (const [eventName, hooks] of hookGroups) {
|
|
40
43
|
for (const [index, hook] of hooks.entries()) {
|
|
41
44
|
const timeout = hook["timeout"]?.trim();
|
|
42
|
-
if (timeout
|
|
45
|
+
if (!isDefined(timeout) ||
|
|
43
46
|
timeout.length === 0 ||
|
|
44
47
|
isNumericTimeoutValue(timeout)) {
|
|
45
48
|
continue;
|
|
@@ -69,6 +72,7 @@ const requireValidAgentHookTimeoutsRule = createCopilotRule({
|
|
|
69
72
|
frozen: false,
|
|
70
73
|
recommended: true,
|
|
71
74
|
requiresTypeChecking: false,
|
|
75
|
+
url: createRuleDocsUrl("require-valid-agent-hook-timeouts"),
|
|
72
76
|
},
|
|
73
77
|
messages: {
|
|
74
78
|
invalidHookTimeout: "Copilot custom agent hook #{{hookNumber}} in `{{eventName}}` should use a numeric `timeout` value in seconds, not `{{timeout}}`.",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-hook-timeouts.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hook-timeouts.ts"],"names":[],"mappings":"
|
|
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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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-hooks`. */
|
|
2
3
|
declare const requireValidAgentHooksRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentHooksRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-hooks.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-hooks.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hooks.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hooks.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hooks.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AAkE7E,mDAAmD;AACnD,QAAA,MAAM,0BAA0B,EAAE,iBAmEhC,CAAC;AAEH,eAAe,0BAA0B,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-valid-agent-hooks`.
|
|
@@ -6,6 +7,7 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterObjectListGroups, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
9
11
|
const hasAnyHookCommand = (hook) => [
|
|
10
12
|
"command",
|
|
11
13
|
"windows",
|
|
@@ -15,6 +17,30 @@ const hasAnyHookCommand = (hook) => [
|
|
|
15
17
|
const value = hook[key];
|
|
16
18
|
return typeof value === "string" && value.trim().length > 0;
|
|
17
19
|
});
|
|
20
|
+
const getInvalidHookReport = (eventName, hook, hookNumber) => {
|
|
21
|
+
const type = hook["type"]?.trim() ?? "";
|
|
22
|
+
if (type !== "command") {
|
|
23
|
+
return {
|
|
24
|
+
data: {
|
|
25
|
+
eventName,
|
|
26
|
+
hookNumber,
|
|
27
|
+
type: type.length === 0 ? "(missing)" : type,
|
|
28
|
+
},
|
|
29
|
+
messageId: "invalidHookType",
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
if (hasAnyHookCommand(hook)) {
|
|
33
|
+
return undefined;
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
data: {
|
|
37
|
+
eventName,
|
|
38
|
+
hookNumber,
|
|
39
|
+
},
|
|
40
|
+
messageId: "missingHookCommand",
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
/** Rule module for `require-valid-agent-hooks`. */
|
|
18
44
|
const requireValidAgentHooksRule = createCopilotRule({
|
|
19
45
|
create(context) {
|
|
20
46
|
return createMarkdownDocumentListener(() => {
|
|
@@ -26,34 +52,17 @@ const requireValidAgentHooksRule = createCopilotRule({
|
|
|
26
52
|
return;
|
|
27
53
|
}
|
|
28
54
|
const hookGroups = getFrontmatterObjectListGroups(frontmatter, "hooks");
|
|
29
|
-
if (hookGroups
|
|
55
|
+
if (!isDefined(hookGroups) || hookGroups.size === 0) {
|
|
30
56
|
return;
|
|
31
57
|
}
|
|
32
58
|
for (const [eventName, hooks] of hookGroups) {
|
|
33
59
|
for (const [index, hook] of hooks.entries()) {
|
|
34
60
|
const hookNumber = String(index + 1);
|
|
35
|
-
const
|
|
36
|
-
if (
|
|
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)) {
|
|
61
|
+
const invalidHookReport = getInvalidHookReport(eventName, hook, hookNumber);
|
|
62
|
+
if (!isDefined(invalidHookReport)) {
|
|
48
63
|
continue;
|
|
49
64
|
}
|
|
50
|
-
reportAtDocumentStart(context,
|
|
51
|
-
data: {
|
|
52
|
-
eventName,
|
|
53
|
-
hookNumber,
|
|
54
|
-
},
|
|
55
|
-
messageId: "missingHookCommand",
|
|
56
|
-
});
|
|
65
|
+
reportAtDocumentStart(context, invalidHookReport);
|
|
57
66
|
return;
|
|
58
67
|
}
|
|
59
68
|
}
|
|
@@ -71,6 +80,7 @@ const requireValidAgentHooksRule = createCopilotRule({
|
|
|
71
80
|
frozen: false,
|
|
72
81
|
recommended: true,
|
|
73
82
|
requiresTypeChecking: false,
|
|
83
|
+
url: createRuleDocsUrl("require-valid-agent-hooks"),
|
|
74
84
|
},
|
|
75
85
|
messages: {
|
|
76
86
|
invalidHookType: "Copilot custom agent hook #{{hookNumber}} in `{{eventName}}` must use `type: command` (current value: `{{type}}`).",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-hooks.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hooks.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-hooks.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-hooks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-invocation-controls`. */
|
|
2
3
|
declare const requireValidAgentInvocationControlsRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentInvocationControlsRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-invocation-controls.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-invocation-controls.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-invocation-controls.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-invocation-controls.d.ts","sourceRoot":"","sources":["../../src/rules/require-valid-agent-invocation-controls.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AA0B7E,iEAAiE;AACjE,QAAA,MAAM,uCAAuC,EAAE,iBAyEzC,CAAC;AAEP,eAAe,uCAAuC,CAAC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { isDefined, setHas } from "ts-extras";
|
|
1
2
|
/**
|
|
2
3
|
* @packageDocumentation
|
|
3
4
|
* ESLint rule implementation for `require-valid-agent-invocation-controls`.
|
|
@@ -6,11 +7,13 @@ import { isCustomAgentFilePath } from "../_internal/copilot-file-kind.js";
|
|
|
6
7
|
import { createCopilotRule } from "../_internal/create-copilot-rule.js";
|
|
7
8
|
import { extractFrontmatter, getFrontmatterScalar, hasFrontmatterField, } from "../_internal/frontmatter.js";
|
|
8
9
|
import { createMarkdownDocumentListener, reportAtDocumentStart, } from "../_internal/markdown-rule.js";
|
|
10
|
+
import { createRuleDocsUrl } from "../_internal/rule-docs-url.js";
|
|
9
11
|
const VALID_BOOLEAN_FIELD_VALUES = new Set(["false", "true"]);
|
|
10
12
|
const INVOCATION_CONTROL_FIELDS = [
|
|
11
13
|
"disable-model-invocation",
|
|
12
14
|
"user-invocable",
|
|
13
15
|
];
|
|
16
|
+
/** Rule module for `require-valid-agent-invocation-controls`. */
|
|
14
17
|
const requireValidAgentInvocationControlsRule = createCopilotRule({
|
|
15
18
|
create(context) {
|
|
16
19
|
return createMarkdownDocumentListener(() => {
|
|
@@ -27,13 +30,13 @@ const requireValidAgentInvocationControlsRule = createCopilotRule({
|
|
|
27
30
|
}
|
|
28
31
|
const fieldValue = getFrontmatterScalar(frontmatter, fieldName);
|
|
29
32
|
const normalizedValue = fieldValue?.trim().toLowerCase();
|
|
30
|
-
if (normalizedValue
|
|
31
|
-
VALID_BOOLEAN_FIELD_VALUES
|
|
33
|
+
if (isDefined(normalizedValue) &&
|
|
34
|
+
setHas(VALID_BOOLEAN_FIELD_VALUES, normalizedValue)) {
|
|
32
35
|
continue;
|
|
33
36
|
}
|
|
34
37
|
reportAtDocumentStart(context, {
|
|
35
38
|
data: {
|
|
36
|
-
currentValue: fieldValue
|
|
39
|
+
currentValue: !isDefined(fieldValue) ||
|
|
37
40
|
fieldValue.trim().length === 0
|
|
38
41
|
? "(empty)"
|
|
39
42
|
: fieldValue,
|
|
@@ -57,6 +60,7 @@ const requireValidAgentInvocationControlsRule = createCopilotRule({
|
|
|
57
60
|
frozen: false,
|
|
58
61
|
recommended: true,
|
|
59
62
|
requiresTypeChecking: false,
|
|
63
|
+
url: createRuleDocsUrl("require-valid-agent-invocation-controls"),
|
|
60
64
|
},
|
|
61
65
|
messages: {
|
|
62
66
|
invalidInvocationControl: "Copilot custom agent `{{fieldName}}` must use a boolean `true` or `false` value (current value: `{{currentValue}}`).",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"require-valid-agent-invocation-controls.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-invocation-controls.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"require-valid-agent-invocation-controls.js","sourceRoot":"","sources":["../../src/rules/require-valid-agent-invocation-controls.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAI9C;;;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;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAElE,MAAM,0BAA0B,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;AAE9D,MAAM,yBAAyB,GAAG;IAC9B,0BAA0B;IAC1B,gBAAgB;CACV,CAAC;AAEX,iEAAiE;AACjE,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,SAAS,CAAC,eAAe,CAAC;oBAC1B,MAAM,CAAC,0BAA0B,EAAE,eAAe,CAAC,EACrD,CAAC;oBACC,SAAS;gBACb,CAAC;gBAED,qBAAqB,CAAC,OAAO,EAAE;oBAC3B,IAAI,EAAE;wBACF,YAAY,EACR,CAAC,SAAS,CAAC,UAAU,CAAC;4BACtB,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,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;YAC3B,GAAG,EAAE,iBAAiB,CAClB,yCAAyC,CAC5C;SACJ;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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { CopilotRuleModule } from "../_internal/create-copilot-rule.js";
|
|
2
|
+
/** Rule module for `require-valid-agent-mcp-servers`. */
|
|
2
3
|
declare const requireValidAgentMcpServersRule: CopilotRuleModule;
|
|
3
4
|
export default requireValidAgentMcpServersRule;
|
|
4
5
|
//# sourceMappingURL=require-valid-agent-mcp-servers.d.ts.map
|