diff --git a/.changeset/patch-add-mcp-tools-to-action-logs.md b/.changeset/patch-add-mcp-tools-to-action-logs.md new file mode 100644 index 0000000000..fa83d6b678 --- /dev/null +++ b/.changeset/patch-add-mcp-tools-to-action-logs.md @@ -0,0 +1,8 @@ +--- +"gh-aw": patch +--- + +Add MCP tools list to action logs. `generatePlainTextSummary()` now writes a formatted +list of available MCP tools to action logs (via `core.info()`), improving visibility +when reviewing execution logs. Tests were added and workflows were recompiled. + diff --git a/.github/workflows/ai-triage-campaign.lock.yml b/.github/workflows/ai-triage-campaign.lock.yml index 43ddaff816..164bac7848 100644 --- a/.github/workflows/ai-triage-campaign.lock.yml +++ b/.github/workflows/ai-triage-campaign.lock.yml @@ -3953,6 +3953,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/archie.lock.yml b/.github/workflows/archie.lock.yml index 1a87178b04..78ed9f0faf 100644 --- a/.github/workflows/archie.lock.yml +++ b/.github/workflows/archie.lock.yml @@ -5614,6 +5614,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/artifacts-summary.lock.yml b/.github/workflows/artifacts-summary.lock.yml index 2ccbab3b53..af2bd4aedd 100644 --- a/.github/workflows/artifacts-summary.lock.yml +++ b/.github/workflows/artifacts-summary.lock.yml @@ -4111,6 +4111,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/audit-workflows.lock.yml b/.github/workflows/audit-workflows.lock.yml index 58421666fb..683b8f64ac 100644 --- a/.github/workflows/audit-workflows.lock.yml +++ b/.github/workflows/audit-workflows.lock.yml @@ -5660,6 +5660,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/blog-auditor.lock.yml b/.github/workflows/blog-auditor.lock.yml index de6307af49..c2ab78b8fb 100644 --- a/.github/workflows/blog-auditor.lock.yml +++ b/.github/workflows/blog-auditor.lock.yml @@ -4722,6 +4722,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/brave.lock.yml b/.github/workflows/brave.lock.yml index c66c9f08b8..db86c467a9 100644 --- a/.github/workflows/brave.lock.yml +++ b/.github/workflows/brave.lock.yml @@ -5404,6 +5404,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/breaking-change-checker.lock.yml b/.github/workflows/breaking-change-checker.lock.yml index 7135680e0c..08cc0e29a1 100644 --- a/.github/workflows/breaking-change-checker.lock.yml +++ b/.github/workflows/breaking-change-checker.lock.yml @@ -4195,6 +4195,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/changeset.lock.yml b/.github/workflows/changeset.lock.yml index 7d684ecd6b..27eb9a262b 100644 --- a/.github/workflows/changeset.lock.yml +++ b/.github/workflows/changeset.lock.yml @@ -5084,6 +5084,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/ci-doctor.lock.yml b/.github/workflows/ci-doctor.lock.yml index c5e1ea7827..0a4461a2dd 100644 --- a/.github/workflows/ci-doctor.lock.yml +++ b/.github/workflows/ci-doctor.lock.yml @@ -4890,6 +4890,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/cli-consistency-checker.lock.yml b/.github/workflows/cli-consistency-checker.lock.yml index 86decb267e..803ca07e90 100644 --- a/.github/workflows/cli-consistency-checker.lock.yml +++ b/.github/workflows/cli-consistency-checker.lock.yml @@ -4192,6 +4192,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/cli-version-checker.lock.yml b/.github/workflows/cli-version-checker.lock.yml index 9ab1c14699..d2f751355c 100644 --- a/.github/workflows/cli-version-checker.lock.yml +++ b/.github/workflows/cli-version-checker.lock.yml @@ -4671,6 +4671,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/cloclo.lock.yml b/.github/workflows/cloclo.lock.yml index 4f7c8e4341..0bb15da156 100644 --- a/.github/workflows/cloclo.lock.yml +++ b/.github/workflows/cloclo.lock.yml @@ -6138,6 +6138,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/close-old-discussions.lock.yml b/.github/workflows/close-old-discussions.lock.yml index 5fa6a8e5f6..b553296553 100644 --- a/.github/workflows/close-old-discussions.lock.yml +++ b/.github/workflows/close-old-discussions.lock.yml @@ -4289,6 +4289,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/commit-changes-analyzer.lock.yml b/.github/workflows/commit-changes-analyzer.lock.yml index 8484d46776..0cd5f563e6 100644 --- a/.github/workflows/commit-changes-analyzer.lock.yml +++ b/.github/workflows/commit-changes-analyzer.lock.yml @@ -4603,6 +4603,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/copilot-agent-analysis.lock.yml b/.github/workflows/copilot-agent-analysis.lock.yml index c62121d1e2..74b627665e 100644 --- a/.github/workflows/copilot-agent-analysis.lock.yml +++ b/.github/workflows/copilot-agent-analysis.lock.yml @@ -5347,6 +5347,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/copilot-pr-merged-report.lock.yml b/.github/workflows/copilot-pr-merged-report.lock.yml index 07e7b163c2..de931eb321 100644 --- a/.github/workflows/copilot-pr-merged-report.lock.yml +++ b/.github/workflows/copilot-pr-merged-report.lock.yml @@ -5744,6 +5744,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/copilot-pr-nlp-analysis.lock.yml b/.github/workflows/copilot-pr-nlp-analysis.lock.yml index 5891f1fa9e..54c982d690 100644 --- a/.github/workflows/copilot-pr-nlp-analysis.lock.yml +++ b/.github/workflows/copilot-pr-nlp-analysis.lock.yml @@ -5732,6 +5732,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/copilot-pr-prompt-analysis.lock.yml b/.github/workflows/copilot-pr-prompt-analysis.lock.yml index 31e9d3afbf..feb46f15fd 100644 --- a/.github/workflows/copilot-pr-prompt-analysis.lock.yml +++ b/.github/workflows/copilot-pr-prompt-analysis.lock.yml @@ -4754,6 +4754,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/copilot-session-insights.lock.yml b/.github/workflows/copilot-session-insights.lock.yml index b0ddab8375..9a1a4f08af 100644 --- a/.github/workflows/copilot-session-insights.lock.yml +++ b/.github/workflows/copilot-session-insights.lock.yml @@ -6757,6 +6757,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/craft.lock.yml b/.github/workflows/craft.lock.yml index b672d25a69..e7405ea38a 100644 --- a/.github/workflows/craft.lock.yml +++ b/.github/workflows/craft.lock.yml @@ -5748,6 +5748,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-assign-issue-to-user.lock.yml b/.github/workflows/daily-assign-issue-to-user.lock.yml index 056cff7327..37bcbaacc2 100644 --- a/.github/workflows/daily-assign-issue-to-user.lock.yml +++ b/.github/workflows/daily-assign-issue-to-user.lock.yml @@ -4389,6 +4389,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-code-metrics.lock.yml b/.github/workflows/daily-code-metrics.lock.yml index cd8c918caa..429a0f7a98 100644 --- a/.github/workflows/daily-code-metrics.lock.yml +++ b/.github/workflows/daily-code-metrics.lock.yml @@ -5798,6 +5798,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-copilot-token-report.lock.yml b/.github/workflows/daily-copilot-token-report.lock.yml index 1dd334ae9e..bb94f18e62 100644 --- a/.github/workflows/daily-copilot-token-report.lock.yml +++ b/.github/workflows/daily-copilot-token-report.lock.yml @@ -5897,6 +5897,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-doc-updater.lock.yml b/.github/workflows/daily-doc-updater.lock.yml index 5b5837313a..6d37c5d537 100644 --- a/.github/workflows/daily-doc-updater.lock.yml +++ b/.github/workflows/daily-doc-updater.lock.yml @@ -4394,6 +4394,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-fact.lock.yml b/.github/workflows/daily-fact.lock.yml index f06db10759..d450515c8a 100644 --- a/.github/workflows/daily-fact.lock.yml +++ b/.github/workflows/daily-fact.lock.yml @@ -4484,6 +4484,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-file-diet.lock.yml b/.github/workflows/daily-file-diet.lock.yml index 2f3d1dbb11..1ddc50389f 100644 --- a/.github/workflows/daily-file-diet.lock.yml +++ b/.github/workflows/daily-file-diet.lock.yml @@ -4438,6 +4438,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-firewall-report.lock.yml b/.github/workflows/daily-firewall-report.lock.yml index 9016aabe15..bbdef80831 100644 --- a/.github/workflows/daily-firewall-report.lock.yml +++ b/.github/workflows/daily-firewall-report.lock.yml @@ -5179,6 +5179,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-issues-report.lock.yml b/.github/workflows/daily-issues-report.lock.yml index a4f15a6645..6dbd5b0096 100644 --- a/.github/workflows/daily-issues-report.lock.yml +++ b/.github/workflows/daily-issues-report.lock.yml @@ -6021,6 +6021,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-malicious-code-scan.lock.yml b/.github/workflows/daily-malicious-code-scan.lock.yml index af2748fe26..e8f9471121 100644 --- a/.github/workflows/daily-malicious-code-scan.lock.yml +++ b/.github/workflows/daily-malicious-code-scan.lock.yml @@ -4425,6 +4425,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-multi-device-docs-tester.lock.yml b/.github/workflows/daily-multi-device-docs-tester.lock.yml index 1fc17de867..aed836e1d8 100644 --- a/.github/workflows/daily-multi-device-docs-tester.lock.yml +++ b/.github/workflows/daily-multi-device-docs-tester.lock.yml @@ -4305,6 +4305,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-news.lock.yml b/.github/workflows/daily-news.lock.yml index 513fb89955..72ea754ad4 100644 --- a/.github/workflows/daily-news.lock.yml +++ b/.github/workflows/daily-news.lock.yml @@ -5656,6 +5656,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-performance-summary.lock.yml b/.github/workflows/daily-performance-summary.lock.yml index 6d06ea9916..b89b4f73cd 100644 --- a/.github/workflows/daily-performance-summary.lock.yml +++ b/.github/workflows/daily-performance-summary.lock.yml @@ -7257,6 +7257,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-repo-chronicle.lock.yml b/.github/workflows/daily-repo-chronicle.lock.yml index 347e7c3098..08290d85b2 100644 --- a/.github/workflows/daily-repo-chronicle.lock.yml +++ b/.github/workflows/daily-repo-chronicle.lock.yml @@ -5330,6 +5330,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-team-status.lock.yml b/.github/workflows/daily-team-status.lock.yml index 21912f8790..8082e635bb 100644 --- a/.github/workflows/daily-team-status.lock.yml +++ b/.github/workflows/daily-team-status.lock.yml @@ -3954,6 +3954,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/daily-workflow-updater.lock.yml b/.github/workflows/daily-workflow-updater.lock.yml index 13e1612436..b56c5f90c1 100644 --- a/.github/workflows/daily-workflow-updater.lock.yml +++ b/.github/workflows/daily-workflow-updater.lock.yml @@ -4117,6 +4117,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/deep-report.lock.yml b/.github/workflows/deep-report.lock.yml index 25682053a7..fbaf193522 100644 --- a/.github/workflows/deep-report.lock.yml +++ b/.github/workflows/deep-report.lock.yml @@ -4900,6 +4900,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/dependabot-go-checker.lock.yml b/.github/workflows/dependabot-go-checker.lock.yml index c53af7d44a..62e3ede321 100644 --- a/.github/workflows/dependabot-go-checker.lock.yml +++ b/.github/workflows/dependabot-go-checker.lock.yml @@ -4725,6 +4725,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/dev-hawk.lock.yml b/.github/workflows/dev-hawk.lock.yml index 799fbb45fc..a4dd5efda6 100644 --- a/.github/workflows/dev-hawk.lock.yml +++ b/.github/workflows/dev-hawk.lock.yml @@ -4658,6 +4658,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/dev.lock.yml b/.github/workflows/dev.lock.yml index af1fc6c70b..887ce44125 100644 --- a/.github/workflows/dev.lock.yml +++ b/.github/workflows/dev.lock.yml @@ -3007,6 +3007,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/developer-docs-consolidator.lock.yml b/.github/workflows/developer-docs-consolidator.lock.yml index 54285bae60..3bb21e0d47 100644 --- a/.github/workflows/developer-docs-consolidator.lock.yml +++ b/.github/workflows/developer-docs-consolidator.lock.yml @@ -5549,6 +5549,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/dictation-prompt.lock.yml b/.github/workflows/dictation-prompt.lock.yml index 203be2cecf..ed405dfac1 100644 --- a/.github/workflows/dictation-prompt.lock.yml +++ b/.github/workflows/dictation-prompt.lock.yml @@ -4065,6 +4065,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/docs-noob-tester.lock.yml b/.github/workflows/docs-noob-tester.lock.yml index d2ad96fdc6..a15887cc62 100644 --- a/.github/workflows/docs-noob-tester.lock.yml +++ b/.github/workflows/docs-noob-tester.lock.yml @@ -4203,6 +4203,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/duplicate-code-detector.lock.yml b/.github/workflows/duplicate-code-detector.lock.yml index 409b7f37fc..6d4e290041 100644 --- a/.github/workflows/duplicate-code-detector.lock.yml +++ b/.github/workflows/duplicate-code-detector.lock.yml @@ -4273,6 +4273,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/example-permissions-warning.lock.yml b/.github/workflows/example-permissions-warning.lock.yml index d50d7713f6..38b0846a54 100644 --- a/.github/workflows/example-permissions-warning.lock.yml +++ b/.github/workflows/example-permissions-warning.lock.yml @@ -1447,6 +1447,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/example-workflow-analyzer.lock.yml b/.github/workflows/example-workflow-analyzer.lock.yml index 673ca36f5c..19b2182ed2 100644 --- a/.github/workflows/example-workflow-analyzer.lock.yml +++ b/.github/workflows/example-workflow-analyzer.lock.yml @@ -4110,6 +4110,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/firewall-escape.lock.yml b/.github/workflows/firewall-escape.lock.yml index da8764ed7d..ca808212f5 100644 --- a/.github/workflows/firewall-escape.lock.yml +++ b/.github/workflows/firewall-escape.lock.yml @@ -1863,6 +1863,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/firewall.lock.yml b/.github/workflows/firewall.lock.yml index 2b3726c01c..e56fee3986 100644 --- a/.github/workflows/firewall.lock.yml +++ b/.github/workflows/firewall.lock.yml @@ -1562,6 +1562,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/github-mcp-structural-analysis.lock.yml b/.github/workflows/github-mcp-structural-analysis.lock.yml index 9882df42f9..cbf0b69c12 100644 --- a/.github/workflows/github-mcp-structural-analysis.lock.yml +++ b/.github/workflows/github-mcp-structural-analysis.lock.yml @@ -5476,6 +5476,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/github-mcp-tools-report.lock.yml b/.github/workflows/github-mcp-tools-report.lock.yml index fb2fc49957..8f3c169d21 100644 --- a/.github/workflows/github-mcp-tools-report.lock.yml +++ b/.github/workflows/github-mcp-tools-report.lock.yml @@ -5252,6 +5252,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/glossary-maintainer.lock.yml b/.github/workflows/glossary-maintainer.lock.yml index c66c6eb876..0d686c74b4 100644 --- a/.github/workflows/glossary-maintainer.lock.yml +++ b/.github/workflows/glossary-maintainer.lock.yml @@ -5223,6 +5223,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/go-fan.lock.yml b/.github/workflows/go-fan.lock.yml index 4baca963cb..01b8485326 100644 --- a/.github/workflows/go-fan.lock.yml +++ b/.github/workflows/go-fan.lock.yml @@ -4793,6 +4793,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/go-logger.lock.yml b/.github/workflows/go-logger.lock.yml index 9e395ab77c..34e71ab676 100644 --- a/.github/workflows/go-logger.lock.yml +++ b/.github/workflows/go-logger.lock.yml @@ -4558,6 +4558,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/go-pattern-detector.lock.yml b/.github/workflows/go-pattern-detector.lock.yml index b21d65291e..3ce8f1fa5b 100644 --- a/.github/workflows/go-pattern-detector.lock.yml +++ b/.github/workflows/go-pattern-detector.lock.yml @@ -4309,6 +4309,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/grumpy-reviewer.lock.yml b/.github/workflows/grumpy-reviewer.lock.yml index 78897323de..4b548c50e0 100644 --- a/.github/workflows/grumpy-reviewer.lock.yml +++ b/.github/workflows/grumpy-reviewer.lock.yml @@ -5553,6 +5553,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/instructions-janitor.lock.yml b/.github/workflows/instructions-janitor.lock.yml index 0b12156225..b9b6531604 100644 --- a/.github/workflows/instructions-janitor.lock.yml +++ b/.github/workflows/instructions-janitor.lock.yml @@ -4323,6 +4323,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/issue-arborist.lock.yml b/.github/workflows/issue-arborist.lock.yml index 79933f384f..e618b71f39 100644 --- a/.github/workflows/issue-arborist.lock.yml +++ b/.github/workflows/issue-arborist.lock.yml @@ -4282,6 +4282,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/issue-monster.lock.yml b/.github/workflows/issue-monster.lock.yml index bbdd516971..fb62bb1f2a 100644 --- a/.github/workflows/issue-monster.lock.yml +++ b/.github/workflows/issue-monster.lock.yml @@ -4825,6 +4825,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/issue-triage-agent.lock.yml b/.github/workflows/issue-triage-agent.lock.yml index d11d900059..388cee4c1e 100644 --- a/.github/workflows/issue-triage-agent.lock.yml +++ b/.github/workflows/issue-triage-agent.lock.yml @@ -4297,6 +4297,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/lockfile-stats.lock.yml b/.github/workflows/lockfile-stats.lock.yml index 1ae45cb0d5..32d314ff0d 100644 --- a/.github/workflows/lockfile-stats.lock.yml +++ b/.github/workflows/lockfile-stats.lock.yml @@ -4835,6 +4835,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/mcp-inspector.lock.yml b/.github/workflows/mcp-inspector.lock.yml index f2ea4c652c..a101474877 100644 --- a/.github/workflows/mcp-inspector.lock.yml +++ b/.github/workflows/mcp-inspector.lock.yml @@ -4733,6 +4733,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/mergefest.lock.yml b/.github/workflows/mergefest.lock.yml index 7b7676c37c..58b49a9f73 100644 --- a/.github/workflows/mergefest.lock.yml +++ b/.github/workflows/mergefest.lock.yml @@ -4898,6 +4898,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/notion-issue-summary.lock.yml b/.github/workflows/notion-issue-summary.lock.yml index 80fe18e70b..979fac652e 100644 --- a/.github/workflows/notion-issue-summary.lock.yml +++ b/.github/workflows/notion-issue-summary.lock.yml @@ -3800,6 +3800,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/org-health-report.lock.yml b/.github/workflows/org-health-report.lock.yml index d17f509e3c..85aa355574 100644 --- a/.github/workflows/org-health-report.lock.yml +++ b/.github/workflows/org-health-report.lock.yml @@ -5594,6 +5594,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/pdf-summary.lock.yml b/.github/workflows/pdf-summary.lock.yml index 370c18df62..2dd1ffc94a 100644 --- a/.github/workflows/pdf-summary.lock.yml +++ b/.github/workflows/pdf-summary.lock.yml @@ -5578,6 +5578,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/plan.lock.yml b/.github/workflows/plan.lock.yml index e4b087b626..6d28417587 100644 --- a/.github/workflows/plan.lock.yml +++ b/.github/workflows/plan.lock.yml @@ -4912,6 +4912,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/poem-bot.lock.yml b/.github/workflows/poem-bot.lock.yml index 73e98b05d4..9a0b7e436b 100644 --- a/.github/workflows/poem-bot.lock.yml +++ b/.github/workflows/poem-bot.lock.yml @@ -6630,6 +6630,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/pr-nitpick-reviewer.lock.yml b/.github/workflows/pr-nitpick-reviewer.lock.yml index ff2e5ec6be..6c847aeae7 100644 --- a/.github/workflows/pr-nitpick-reviewer.lock.yml +++ b/.github/workflows/pr-nitpick-reviewer.lock.yml @@ -5898,6 +5898,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/prompt-clustering-analysis.lock.yml b/.github/workflows/prompt-clustering-analysis.lock.yml index 868ce11f27..92d1b33963 100644 --- a/.github/workflows/prompt-clustering-analysis.lock.yml +++ b/.github/workflows/prompt-clustering-analysis.lock.yml @@ -6111,6 +6111,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/python-data-charts.lock.yml b/.github/workflows/python-data-charts.lock.yml index 7242e09091..35b9813b6d 100644 --- a/.github/workflows/python-data-charts.lock.yml +++ b/.github/workflows/python-data-charts.lock.yml @@ -5962,6 +5962,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/q.lock.yml b/.github/workflows/q.lock.yml index 5d2289b5fb..eb2da6486d 100644 --- a/.github/workflows/q.lock.yml +++ b/.github/workflows/q.lock.yml @@ -6160,6 +6160,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/release.lock.yml b/.github/workflows/release.lock.yml index 25f1d66a81..066f74ea35 100644 --- a/.github/workflows/release.lock.yml +++ b/.github/workflows/release.lock.yml @@ -4258,6 +4258,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/repo-tree-map.lock.yml b/.github/workflows/repo-tree-map.lock.yml index 5663b899a4..5d3bc7810e 100644 --- a/.github/workflows/repo-tree-map.lock.yml +++ b/.github/workflows/repo-tree-map.lock.yml @@ -4138,6 +4138,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/repository-quality-improver.lock.yml b/.github/workflows/repository-quality-improver.lock.yml index 4f2315742a..9f67b2ded5 100644 --- a/.github/workflows/repository-quality-improver.lock.yml +++ b/.github/workflows/repository-quality-improver.lock.yml @@ -5176,6 +5176,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/research.lock.yml b/.github/workflows/research.lock.yml index a40c470158..cb53920d30 100644 --- a/.github/workflows/research.lock.yml +++ b/.github/workflows/research.lock.yml @@ -4053,6 +4053,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/safe-output-health.lock.yml b/.github/workflows/safe-output-health.lock.yml index 59de576d79..0fec443e39 100644 --- a/.github/workflows/safe-output-health.lock.yml +++ b/.github/workflows/safe-output-health.lock.yml @@ -5132,6 +5132,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/schema-consistency-checker.lock.yml b/.github/workflows/schema-consistency-checker.lock.yml index e32acd6633..b09b77531b 100644 --- a/.github/workflows/schema-consistency-checker.lock.yml +++ b/.github/workflows/schema-consistency-checker.lock.yml @@ -4780,6 +4780,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/scout.lock.yml b/.github/workflows/scout.lock.yml index 7a238fe10d..51bbe76362 100644 --- a/.github/workflows/scout.lock.yml +++ b/.github/workflows/scout.lock.yml @@ -6186,6 +6186,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/security-fix-pr.lock.yml b/.github/workflows/security-fix-pr.lock.yml index 802de31c72..4e3ac57701 100644 --- a/.github/workflows/security-fix-pr.lock.yml +++ b/.github/workflows/security-fix-pr.lock.yml @@ -4330,6 +4330,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/semantic-function-refactor.lock.yml b/.github/workflows/semantic-function-refactor.lock.yml index 80084fd586..1aaf18fe0c 100644 --- a/.github/workflows/semantic-function-refactor.lock.yml +++ b/.github/workflows/semantic-function-refactor.lock.yml @@ -5168,6 +5168,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-claude.lock.yml b/.github/workflows/smoke-claude.lock.yml index de354189de..2029a90cca 100644 --- a/.github/workflows/smoke-claude.lock.yml +++ b/.github/workflows/smoke-claude.lock.yml @@ -6067,6 +6067,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-codex.lock.yml b/.github/workflows/smoke-codex.lock.yml index a31922d99d..7c66d8f74d 100644 --- a/.github/workflows/smoke-codex.lock.yml +++ b/.github/workflows/smoke-codex.lock.yml @@ -5626,6 +5626,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-copilot-no-firewall.lock.yml b/.github/workflows/smoke-copilot-no-firewall.lock.yml index 98fa0d7515..c427811d6f 100644 --- a/.github/workflows/smoke-copilot-no-firewall.lock.yml +++ b/.github/workflows/smoke-copilot-no-firewall.lock.yml @@ -7160,6 +7160,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-copilot-playwright.lock.yml b/.github/workflows/smoke-copilot-playwright.lock.yml index d00c62b682..4c1953edb6 100644 --- a/.github/workflows/smoke-copilot-playwright.lock.yml +++ b/.github/workflows/smoke-copilot-playwright.lock.yml @@ -7144,6 +7144,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-copilot-safe-inputs.lock.yml b/.github/workflows/smoke-copilot-safe-inputs.lock.yml index 52b6856904..bf5203b339 100644 --- a/.github/workflows/smoke-copilot-safe-inputs.lock.yml +++ b/.github/workflows/smoke-copilot-safe-inputs.lock.yml @@ -6869,6 +6869,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-copilot.lock.yml b/.github/workflows/smoke-copilot.lock.yml index c055a23577..aa316f9487 100644 --- a/.github/workflows/smoke-copilot.lock.yml +++ b/.github/workflows/smoke-copilot.lock.yml @@ -7042,6 +7042,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-detector.lock.yml b/.github/workflows/smoke-detector.lock.yml index ed706834c3..ac3bcee9fa 100644 --- a/.github/workflows/smoke-detector.lock.yml +++ b/.github/workflows/smoke-detector.lock.yml @@ -5810,6 +5810,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-srt-custom-config.lock.yml b/.github/workflows/smoke-srt-custom-config.lock.yml index 01a1ef4ec0..5bb0dade68 100644 --- a/.github/workflows/smoke-srt-custom-config.lock.yml +++ b/.github/workflows/smoke-srt-custom-config.lock.yml @@ -1739,6 +1739,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/smoke-srt.lock.yml b/.github/workflows/smoke-srt.lock.yml index 193655597d..07ee89320e 100644 --- a/.github/workflows/smoke-srt.lock.yml +++ b/.github/workflows/smoke-srt.lock.yml @@ -3945,6 +3945,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/spec-kit-execute.lock.yml b/.github/workflows/spec-kit-execute.lock.yml index fc88388f54..03b678283f 100644 --- a/.github/workflows/spec-kit-execute.lock.yml +++ b/.github/workflows/spec-kit-execute.lock.yml @@ -648,11 +648,6 @@ jobs: restore-keys: | memory-${{ github.workflow }}- memory- - - name: Upload cache-memory data as artifact - uses: actions/upload-artifact@330a01c490aca151604b8cf639adc76d48f6c5d4 # v5 - with: - name: cache-memory - path: /tmp/gh-aw/cache-memory # Repo memory git-based storage configuration from frontmatter processed below - name: Clone repo-memory branch (default) env: @@ -4672,6 +4667,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { @@ -5651,6 +5713,12 @@ jobs: path: /tmp/gh-aw/repo-memory-default retention-days: 1 if-no-files-found: ignore + - name: Upload cache-memory data as artifact + uses: actions/upload-artifact@330a01c490aca151604b8cf639adc76d48f6c5d4 # v5 + if: always() + with: + name: cache-memory + path: /tmp/gh-aw/cache-memory - name: Validate agent logs for errors if: always() uses: actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v8 diff --git a/.github/workflows/spec-kit-executor.lock.yml b/.github/workflows/spec-kit-executor.lock.yml index 4107ea98f7..c3e18afccc 100644 --- a/.github/workflows/spec-kit-executor.lock.yml +++ b/.github/workflows/spec-kit-executor.lock.yml @@ -4357,6 +4357,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/speckit-dispatcher.lock.yml b/.github/workflows/speckit-dispatcher.lock.yml index 18fc8d3ca3..e1da3cb6e1 100644 --- a/.github/workflows/speckit-dispatcher.lock.yml +++ b/.github/workflows/speckit-dispatcher.lock.yml @@ -6076,6 +6076,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/stale-repo-identifier.lock.yml b/.github/workflows/stale-repo-identifier.lock.yml index eec13ac4b2..74aab2c48b 100644 --- a/.github/workflows/stale-repo-identifier.lock.yml +++ b/.github/workflows/stale-repo-identifier.lock.yml @@ -5830,6 +5830,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/static-analysis-report.lock.yml b/.github/workflows/static-analysis-report.lock.yml index 770c1fe286..5b4b66d3b3 100644 --- a/.github/workflows/static-analysis-report.lock.yml +++ b/.github/workflows/static-analysis-report.lock.yml @@ -4871,6 +4871,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/super-linter.lock.yml b/.github/workflows/super-linter.lock.yml index e019103d26..7591e6326f 100644 --- a/.github/workflows/super-linter.lock.yml +++ b/.github/workflows/super-linter.lock.yml @@ -4354,6 +4354,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/technical-doc-writer.lock.yml b/.github/workflows/technical-doc-writer.lock.yml index 021ce0e9a0..c5c4fc41e1 100644 --- a/.github/workflows/technical-doc-writer.lock.yml +++ b/.github/workflows/technical-doc-writer.lock.yml @@ -5411,6 +5411,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/test-discussion-expires.lock.yml b/.github/workflows/test-discussion-expires.lock.yml index d4e01241a6..3a70576315 100644 --- a/.github/workflows/test-discussion-expires.lock.yml +++ b/.github/workflows/test-discussion-expires.lock.yml @@ -3732,6 +3732,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/test-python-safe-input.lock.yml b/.github/workflows/test-python-safe-input.lock.yml index f568fbf947..fecf7546db 100644 --- a/.github/workflows/test-python-safe-input.lock.yml +++ b/.github/workflows/test-python-safe-input.lock.yml @@ -5354,6 +5354,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/tidy.lock.yml b/.github/workflows/tidy.lock.yml index 7f6c108eb2..bbf3a3d908 100644 --- a/.github/workflows/tidy.lock.yml +++ b/.github/workflows/tidy.lock.yml @@ -4471,6 +4471,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/typist.lock.yml b/.github/workflows/typist.lock.yml index 069d88a040..dbb161163c 100644 --- a/.github/workflows/typist.lock.yml +++ b/.github/workflows/typist.lock.yml @@ -5199,6 +5199,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/unbloat-docs.lock.yml b/.github/workflows/unbloat-docs.lock.yml index 5061f35e08..408e05227c 100644 --- a/.github/workflows/unbloat-docs.lock.yml +++ b/.github/workflows/unbloat-docs.lock.yml @@ -5932,6 +5932,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/video-analyzer.lock.yml b/.github/workflows/video-analyzer.lock.yml index c773dbc1ee..faffe2ac76 100644 --- a/.github/workflows/video-analyzer.lock.yml +++ b/.github/workflows/video-analyzer.lock.yml @@ -4395,6 +4395,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/.github/workflows/weekly-issue-summary.lock.yml b/.github/workflows/weekly-issue-summary.lock.yml index 92af1b2fc7..d091ce9300 100644 --- a/.github/workflows/weekly-issue-summary.lock.yml +++ b/.github/workflows/weekly-issue-summary.lock.yml @@ -5187,6 +5187,73 @@ jobs: lines.push(`Model: ${model}`); } lines.push(""); + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + const internalTools = ["fetch_copilot_cli_documentation"]; + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } const toolUsePairs = new Map(); for (const entry of logEntries) { if (entry.type === "user" && entry.message?.content) { diff --git a/pkg/workflow/js/log_parser_shared.cjs b/pkg/workflow/js/log_parser_shared.cjs index 50e7d210bd..5beaaebf22 100644 --- a/pkg/workflow/js/log_parser_shared.cjs +++ b/pkg/workflow/js/log_parser_shared.cjs @@ -982,6 +982,89 @@ function generatePlainTextSummary(logEntries, options = {}) { } lines.push(""); + // Add Available Tools section from init entry + const initEntry = logEntries.find(entry => entry.type === "system" && entry.subtype === "init"); + if (initEntry && initEntry.tools && Array.isArray(initEntry.tools) && initEntry.tools.length > 0) { + lines.push("Available Tools:"); + lines.push(""); + + // Categorize tools using the same logic as formatInitializationSummary + /** @type {{ [key: string]: string[] }} */ + const categories = { + Builtin: [], + "Safe Outputs": [], + "Safe Inputs": [], + "Git/GitHub": [], + Playwright: [], + Serena: [], + MCP: [], + "Custom Agents": [], + Other: [], + }; + + // Builtin tools that come with gh-aw / Copilot + const builtinTools = [ + "bash", + "write_bash", + "read_bash", + "stop_bash", + "list_bash", + "grep", + "glob", + "view", + "create", + "edit", + "store_memory", + "code_review", + "codeql_checker", + "report_progress", + "report_intent", + "gh-advisory-database", + ]; + + // Internal tools that are specific to Copilot CLI + const internalTools = ["fetch_copilot_cli_documentation"]; + + for (const tool of initEntry.tools) { + const toolLower = tool.toLowerCase(); + + if (builtinTools.includes(toolLower) || internalTools.includes(toolLower)) { + categories["Builtin"].push(tool); + } else if (tool.startsWith("safeoutputs-") || tool.startsWith("safe_outputs-")) { + // Extract the tool name without the prefix for cleaner display + const toolName = tool.replace(/^safeoutputs-|^safe_outputs-/, ""); + categories["Safe Outputs"].push(toolName); + } else if (tool.startsWith("safeinputs-") || tool.startsWith("safe_inputs-")) { + // Extract the tool name without the prefix for cleaner display + const toolName = tool.replace(/^safeinputs-|^safe_inputs-/, ""); + categories["Safe Inputs"].push(toolName); + } else if (tool.startsWith("mcp__github__")) { + categories["Git/GitHub"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__playwright__")) { + categories["Playwright"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__serena__")) { + categories["Serena"].push(formatMcpName(tool)); + } else if (tool.startsWith("mcp__") || ["ListMcpResourcesTool", "ReadMcpResourceTool"].includes(tool)) { + categories["MCP"].push(tool.startsWith("mcp__") ? formatMcpName(tool) : tool); + } else if (isLikelyCustomAgent(tool)) { + // Custom agents typically have hyphenated names (kebab-case) + categories["Custom Agents"].push(tool); + } else { + categories["Other"].push(tool); + } + } + + // Display categories with tools + for (const [category, tools] of Object.entries(categories)) { + if (tools.length > 0) { + const toolText = tools.length === 1 ? "tool" : "tools"; + lines.push(`${category}: ${tools.length} ${toolText}`); + lines.push(tools.join(", ")); + } + } + lines.push(""); + } + // Collect tool usage summary const toolUsePairs = new Map(); for (const entry of logEntries) { diff --git a/pkg/workflow/js/log_parser_shared.test.cjs b/pkg/workflow/js/log_parser_shared.test.cjs index 9fbd31eebb..be45003ca3 100644 --- a/pkg/workflow/js/log_parser_shared.test.cjs +++ b/pkg/workflow/js/log_parser_shared.test.cjs @@ -1533,5 +1533,71 @@ describe("log_parser_shared.cjs", () => { expect(result).not.toContain("Read"); expect(result).not.toContain("Write"); }); + + it("should include Available Tools section from init entry", async () => { + const { generatePlainTextSummary } = await import("./log_parser_shared.cjs"); + + const logEntries = [ + { + type: "system", + subtype: "init", + model: "test-model", + tools: [ + "bash", + "view", + "create", + "edit", + "mcp__github__search_issues", + "mcp__github__create_issue", + "mcp__playwright__navigate", + "safeoutputs-create_issue", + "safeoutputs-add_comment", + "create-agentic-workflow", + "debug-agentic-workflow", + ], + }, + { type: "result", num_turns: 1 }, + ]; + + const result = generatePlainTextSummary(logEntries, { parserName: "Agent" }); + + expect(result).toContain("Available Tools:"); + expect(result).toContain("Builtin: 4 tools"); + expect(result).toContain("bash, view, create, edit"); + expect(result).toContain("Git/GitHub: 2 tools"); + expect(result).toContain("github::search_issues, github::create_issue"); + expect(result).toContain("Playwright: 1 tool"); + expect(result).toContain("playwright::navigate"); + expect(result).toContain("Safe Outputs: 2 tools"); + expect(result).toContain("create_issue, add_comment"); + expect(result).toContain("Custom Agents: 2 tools"); + expect(result).toContain("create-agentic-workflow, debug-agentic-workflow"); + }); + + it("should handle empty tools list gracefully", async () => { + const { generatePlainTextSummary } = await import("./log_parser_shared.cjs"); + + const logEntries = [ + { type: "system", subtype: "init", model: "test-model", tools: [] }, + { type: "result", num_turns: 1 }, + ]; + + const result = generatePlainTextSummary(logEntries, { parserName: "Agent" }); + + // Should not contain Available Tools section if no tools + expect(result).not.toContain("Available Tools:"); + }); + + it("should work without init entry", async () => { + const { generatePlainTextSummary } = await import("./log_parser_shared.cjs"); + + const logEntries = [{ type: "result", num_turns: 1 }]; + + const result = generatePlainTextSummary(logEntries, { parserName: "Agent" }); + + // Should work without init entry + expect(result).toContain("=== Agent Execution Summary ==="); + expect(result).not.toContain("Available Tools:"); + }); }); });