mirror of
https://github.com/anthropics/claude-code.git
synced 2026-02-19 04:27:33 -08:00
Compare commits
46 Commits
claude/add
...
claude/sla
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
69585d4ffa | ||
|
|
19bb071fe0 | ||
|
|
85f2807991 | ||
|
|
e7f36bcdf0 | ||
|
|
2bc62d1456 | ||
|
|
ef1e0ac098 | ||
|
|
d7e3cfb31c | ||
|
|
bd78b216ed | ||
|
|
a4e0c5b4c8 | ||
|
|
36d9ee2c2e | ||
|
|
4936302293 | ||
|
|
43d0eac708 | ||
|
|
f298d940fa | ||
|
|
34f551fa91 | ||
|
|
90c07d1c7e | ||
|
|
f93f614768 | ||
|
|
e58014371b | ||
|
|
5862adf641 | ||
|
|
38f1f93052 | ||
|
|
cf98f1d943 | ||
|
|
266d7c8c9f | ||
|
|
73eddfd640 | ||
|
|
8c48d2f508 | ||
|
|
3f9a645986 | ||
|
|
9f6b6d17de | ||
|
|
e9a9efc121 | ||
|
|
10e6348e77 | ||
|
|
e431f5b496 | ||
|
|
052a1317c0 | ||
|
|
a6a8045031 | ||
|
|
74cc597eb5 | ||
|
|
923d727492 | ||
|
|
fb3a947cb5 | ||
|
|
2961ddcafe | ||
|
|
fd8f3801b9 | ||
|
|
26315247e7 | ||
|
|
5a91286a82 | ||
|
|
3196f36cee | ||
|
|
7d22b6e167 | ||
|
|
19a829ba68 | ||
|
|
18979efb8d | ||
|
|
f77acdf149 | ||
|
|
c13cf781ef | ||
|
|
cc70d3ab50 | ||
|
|
250b257c4e | ||
|
|
dec754edc9 |
5
.github/workflows/claude-dedupe-issues.yml
vendored
5
.github/workflows/claude-dedupe-issues.yml
vendored
@@ -17,16 +17,19 @@ jobs:
|
||||
permissions:
|
||||
contents: read
|
||||
issues: write
|
||||
id-token: write
|
||||
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Run Claude Code slash command
|
||||
uses: anthropics/claude-code-base-action@v1
|
||||
uses: anthropics/claude-code-action@v1
|
||||
env:
|
||||
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
with:
|
||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
||||
allowed_non_write_users: "*"
|
||||
prompt: "/dedupe ${{ github.repository }}/issues/${{ github.event.issue.number || inputs.issue_number }}"
|
||||
anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}
|
||||
claude_args: "--model claude-sonnet-4-5-20250929"
|
||||
|
||||
109
.github/workflows/claude-issue-triage.yml
vendored
109
.github/workflows/claude-issue-triage.yml
vendored
@@ -11,65 +11,12 @@ jobs:
|
||||
permissions:
|
||||
contents: read
|
||||
issues: write
|
||||
id-token: write
|
||||
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Create triage prompt
|
||||
run: |
|
||||
mkdir -p /tmp/claude-prompts
|
||||
cat > /tmp/claude-prompts/triage-prompt.txt << 'EOF'
|
||||
You're an issue triage assistant for GitHub issues. Your task is to analyze the issue and select appropriate labels from the provided list.
|
||||
|
||||
IMPORTANT: Don't post any comments or messages to the issue. Your only action should be to apply labels.
|
||||
|
||||
Issue Information:
|
||||
- REPO: ${{ github.repository }}
|
||||
- ISSUE_NUMBER: ${{ github.event.issue.number }}
|
||||
|
||||
TASK OVERVIEW:
|
||||
|
||||
1. First, fetch the list of labels available in this repository by running: `gh label list`. Run exactly this command with nothing else.
|
||||
|
||||
2. Next, use the GitHub tools to get context about the issue:
|
||||
- You have access to these tools:
|
||||
- mcp__github__get_issue: Use this to retrieve the current issue's details including title, description, and existing labels
|
||||
- mcp__github__get_issue_comments: Use this to read any discussion or additional context provided in the comments
|
||||
- mcp__github__update_issue: Use this to apply labels to the issue (do not use this for commenting)
|
||||
- mcp__github__search_issues: Use this to find similar issues that might provide context for proper categorization and to identify potential duplicate issues
|
||||
- mcp__github__list_issues: Use this to understand patterns in how other issues are labeled
|
||||
- Start by using mcp__github__get_issue to get the issue details
|
||||
|
||||
3. Analyze the issue content, considering:
|
||||
- The issue title and description
|
||||
- The type of issue (bug report, feature request, question, etc.)
|
||||
- Technical areas mentioned
|
||||
- Severity or priority indicators
|
||||
- User impact
|
||||
- Components affected
|
||||
|
||||
4. Select appropriate labels from the available labels list provided above:
|
||||
- Choose labels that accurately reflect the issue's nature
|
||||
- Be specific but comprehensive
|
||||
- Select priority labels if you can determine urgency (high-priority, med-priority, or low-priority)
|
||||
- Consider platform labels (android, ios) if applicable
|
||||
- If you find similar issues using mcp__github__search_issues, consider using a "duplicate" label if appropriate. Only do so if the issue is a duplicate of another OPEN issue.
|
||||
|
||||
5. Apply the selected labels:
|
||||
- Use mcp__github__update_issue to apply your selected labels
|
||||
- DO NOT post any comments explaining your decision
|
||||
- DO NOT communicate directly with users
|
||||
- If no labels are clearly applicable, do not apply any labels
|
||||
|
||||
IMPORTANT GUIDELINES:
|
||||
- Be thorough in your analysis
|
||||
- Only select labels from the provided list above
|
||||
- DO NOT post any comments to the issue
|
||||
- Your ONLY action should be to apply labels using mcp__github__update_issue
|
||||
- It's okay to not add any labels if none are clearly applicable
|
||||
EOF
|
||||
|
||||
- name: Setup GitHub MCP Server
|
||||
run: |
|
||||
mkdir -p /tmp/mcp-config
|
||||
@@ -96,11 +43,61 @@ jobs:
|
||||
|
||||
- name: Run Claude Code for Issue Triage
|
||||
timeout-minutes: 5
|
||||
uses: anthropics/claude-code-base-action@v1
|
||||
uses: anthropics/claude-code-action@v1
|
||||
env:
|
||||
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
with:
|
||||
prompt_file: /tmp/claude-prompts/triage-prompt.txt
|
||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
||||
allowed_non_write_users: "*"
|
||||
prompt: |
|
||||
You're an issue triage assistant for GitHub issues. Your task is to analyze the issue and select appropriate labels from the provided list.
|
||||
|
||||
IMPORTANT: Don't post any comments or messages to the issue. Your only action should be to apply labels.
|
||||
|
||||
Issue Information:
|
||||
- REPO: ${{ github.repository }}
|
||||
- ISSUE_NUMBER: ${{ github.event.issue.number }}
|
||||
|
||||
TASK OVERVIEW:
|
||||
|
||||
1. First, fetch the list of labels available in this repository by running: `gh label list`. Run exactly this command with nothing else.
|
||||
|
||||
2. Next, use the GitHub tools to get context about the issue:
|
||||
- You have access to these tools:
|
||||
- mcp__github__get_issue: Use this to retrieve the current issue's details including title, description, and existing labels
|
||||
- mcp__github__get_issue_comments: Use this to read any discussion or additional context provided in the comments
|
||||
- mcp__github__update_issue: Use this to apply labels to the issue (do not use this for commenting)
|
||||
- mcp__github__search_issues: Use this to find similar issues that might provide context for proper categorization and to identify potential duplicate issues
|
||||
- mcp__github__list_issues: Use this to understand patterns in how other issues are labeled
|
||||
- Start by using mcp__github__get_issue to get the issue details
|
||||
|
||||
3. Analyze the issue content, considering:
|
||||
- The issue title and description
|
||||
- The type of issue (bug report, feature request, question, etc.)
|
||||
- Technical areas mentioned
|
||||
- Severity or priority indicators
|
||||
- User impact
|
||||
- Components affected
|
||||
|
||||
4. Select appropriate labels from the available labels list provided above:
|
||||
- Choose labels that accurately reflect the issue's nature
|
||||
- Be specific but comprehensive
|
||||
- Select priority labels if you can determine urgency (high-priority, med-priority, or low-priority)
|
||||
- Consider platform labels (android, ios) if applicable
|
||||
- If you find similar issues using mcp__github__search_issues, consider using a "duplicate" label if appropriate. Only do so if the issue is a duplicate of another OPEN issue.
|
||||
|
||||
5. Apply the selected labels:
|
||||
- Use mcp__github__update_issue to apply your selected labels
|
||||
- DO NOT post any comments explaining your decision
|
||||
- DO NOT communicate directly with users
|
||||
- If no labels are clearly applicable, do not apply any labels
|
||||
|
||||
IMPORTANT GUIDELINES:
|
||||
- Be thorough in your analysis
|
||||
- Only select labels from the provided list above
|
||||
- DO NOT post any comments to the issue
|
||||
- Your ONLY action should be to apply labels using mcp__github__update_issue
|
||||
- It's okay to not add any labels if none are clearly applicable
|
||||
anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}
|
||||
claude_args: |
|
||||
--model claude-sonnet-4-5-20250929
|
||||
|
||||
127
.github/workflows/oncall-triage.yml
vendored
127
.github/workflows/oncall-triage.yml
vendored
@@ -16,74 +16,12 @@ jobs:
|
||||
permissions:
|
||||
contents: read
|
||||
issues: write
|
||||
id-token: write
|
||||
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Create oncall triage prompt
|
||||
run: |
|
||||
mkdir -p /tmp/claude-prompts
|
||||
cat > /tmp/claude-prompts/oncall-triage-prompt.txt << 'EOF'
|
||||
You're an oncall triage assistant for GitHub issues. Your task is to identify critical issues that require immediate oncall attention.
|
||||
|
||||
Important: Don't post any comments or messages to the issues. Your only action should be to apply the "oncall" label to qualifying issues.
|
||||
|
||||
Repository: ${{ github.repository }}
|
||||
|
||||
Task overview:
|
||||
1. Fetch all open issues updated in the last 3 days:
|
||||
- Use mcp__github__list_issues with:
|
||||
- state="open"
|
||||
- first=5 (fetch only 5 issues per page)
|
||||
- orderBy="UPDATED_AT"
|
||||
- direction="DESC"
|
||||
- This will give you the most recently updated issues first
|
||||
- For each page of results, check the updatedAt timestamp of each issue
|
||||
- Add issues updated within the last 3 days (72 hours) to your TODO list as you go
|
||||
- Keep paginating using the 'after' parameter until you encounter issues older than 3 days
|
||||
- Once you hit issues older than 3 days, you can stop fetching (no need to fetch all open issues)
|
||||
|
||||
2. Build your TODO list incrementally as you fetch:
|
||||
- As you fetch each page, immediately add qualifying issues to your TODO list
|
||||
- One TODO item per issue number (e.g., "Evaluate issue #123")
|
||||
- This allows you to start processing while still fetching more pages
|
||||
|
||||
3. For each issue in your TODO list:
|
||||
- Use mcp__github__get_issue to read the issue details (title, body, labels)
|
||||
- Use mcp__github__get_issue_comments to read all comments
|
||||
- Evaluate whether this issue needs the oncall label:
|
||||
a) Is it a bug? (has "bug" label or describes bug behavior)
|
||||
b) Does it have at least 50 engagements? (count comments + reactions)
|
||||
c) Is it truly blocking? Read and understand the full content to determine:
|
||||
- Does this prevent core functionality from working?
|
||||
- Can users work around it?
|
||||
- Consider severity indicators: "crash", "stuck", "frozen", "hang", "unresponsive", "cannot use", "blocked", "broken"
|
||||
- Be conservative - only flag issues that truly prevent users from getting work done
|
||||
|
||||
4. For issues that meet all criteria and do not already have the "oncall" label:
|
||||
- Use mcp__github__update_issue to add the "oncall" label
|
||||
- Do not post any comments
|
||||
- Do not remove any existing labels
|
||||
- Do not remove the "oncall" label from issues that already have it
|
||||
|
||||
Important guidelines:
|
||||
- Use the TODO list to track your progress through ALL candidate issues
|
||||
- Process issues efficiently - don't read every single issue upfront, work through your TODO list systematically
|
||||
- Be conservative in your assessment - only flag truly critical blocking issues
|
||||
- Do not post any comments to issues
|
||||
- Your only action should be to add the "oncall" label using mcp__github__update_issue
|
||||
- Mark each issue as complete in your TODO list as you process it
|
||||
|
||||
7. After processing all issues in your TODO list, provide a summary of your actions:
|
||||
- Total number of issues processed (candidate issues evaluated)
|
||||
- Number of issues that received the "oncall" label
|
||||
- For each issue that got the label: list issue number, title, and brief reason why it qualified
|
||||
- Close calls: List any issues that almost qualified but didn't quite meet the criteria (e.g., borderline blocking, had workarounds)
|
||||
- If no issues qualified, state that clearly
|
||||
- Format the summary clearly for easy reading
|
||||
EOF
|
||||
|
||||
- name: Setup GitHub MCP Server
|
||||
run: |
|
||||
mkdir -p /tmp/mcp-config
|
||||
@@ -110,11 +48,70 @@ jobs:
|
||||
|
||||
- name: Run Claude Code for Oncall Triage
|
||||
timeout-minutes: 10
|
||||
uses: anthropics/claude-code-base-action@v1
|
||||
uses: anthropics/claude-code-action@v1
|
||||
env:
|
||||
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
with:
|
||||
prompt_file: /tmp/claude-prompts/oncall-triage-prompt.txt
|
||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
||||
allowed_non_write_users: "*"
|
||||
prompt: |
|
||||
You're an oncall triage assistant for GitHub issues. Your task is to identify critical issues that require immediate oncall attention.
|
||||
|
||||
Important: Don't post any comments or messages to the issues. Your only action should be to apply the "oncall" label to qualifying issues.
|
||||
|
||||
Repository: ${{ github.repository }}
|
||||
|
||||
Task overview:
|
||||
1. Fetch all open issues updated in the last 3 days:
|
||||
- Use mcp__github__list_issues with:
|
||||
- state="open"
|
||||
- first=5 (fetch only 5 issues per page)
|
||||
- orderBy="UPDATED_AT"
|
||||
- direction="DESC"
|
||||
- This will give you the most recently updated issues first
|
||||
- For each page of results, check the updatedAt timestamp of each issue
|
||||
- Add issues updated within the last 3 days (72 hours) to your TODO list as you go
|
||||
- Keep paginating using the 'after' parameter until you encounter issues older than 3 days
|
||||
- Once you hit issues older than 3 days, you can stop fetching (no need to fetch all open issues)
|
||||
|
||||
2. Build your TODO list incrementally as you fetch:
|
||||
- As you fetch each page, immediately add qualifying issues to your TODO list
|
||||
- One TODO item per issue number (e.g., "Evaluate issue #123")
|
||||
- This allows you to start processing while still fetching more pages
|
||||
|
||||
3. For each issue in your TODO list:
|
||||
- Use mcp__github__get_issue to read the issue details (title, body, labels)
|
||||
- Use mcp__github__get_issue_comments to read all comments
|
||||
- Evaluate whether this issue needs the oncall label:
|
||||
a) Is it a bug? (has "bug" label or describes bug behavior)
|
||||
b) Does it have at least 50 engagements? (count comments + reactions)
|
||||
c) Is it truly blocking? Read and understand the full content to determine:
|
||||
- Does this prevent core functionality from working?
|
||||
- Can users work around it?
|
||||
- Consider severity indicators: "crash", "stuck", "frozen", "hang", "unresponsive", "cannot use", "blocked", "broken"
|
||||
- Be conservative - only flag issues that truly prevent users from getting work done
|
||||
|
||||
4. For issues that meet all criteria and do not already have the "oncall" label:
|
||||
- Use mcp__github__update_issue to add the "oncall" label
|
||||
- Do not post any comments
|
||||
- Do not remove any existing labels
|
||||
- Do not remove the "oncall" label from issues that already have it
|
||||
|
||||
Important guidelines:
|
||||
- Use the TODO list to track your progress through ALL candidate issues
|
||||
- Process issues efficiently - don't read every single issue upfront, work through your TODO list systematically
|
||||
- Be conservative in your assessment - only flag truly critical blocking issues
|
||||
- Do not post any comments to issues
|
||||
- Your only action should be to add the "oncall" label using mcp__github__update_issue
|
||||
- Mark each issue as complete in your TODO list as you process it
|
||||
|
||||
7. After processing all issues in your TODO list, provide a summary of your actions:
|
||||
- Total number of issues processed (candidate issues evaluated)
|
||||
- Number of issues that received the "oncall" label
|
||||
- For each issue that got the label: list issue number, title, and brief reason why it qualified
|
||||
- Close calls: List any issues that almost qualified but didn't quite meet the criteria (e.g., borderline blocking, had workarounds)
|
||||
- If no issues qualified, state that clearly
|
||||
- Format the summary clearly for easy reading
|
||||
anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}
|
||||
claude_args: |
|
||||
--mcp-config /tmp/mcp-config/mcp-servers.json
|
||||
|
||||
268
CHANGELOG.md
268
CHANGELOG.md
@@ -1,5 +1,271 @@
|
||||
# Changelog
|
||||
|
||||
## 2.1.38
|
||||
|
||||
- Fixed VS Code terminal scroll-to-top regression introduced in 2.1.37
|
||||
- Fixed Tab key queueing slash commands instead of autocompleting
|
||||
- Fixed bash permission matching for commands using environment variable wrappers
|
||||
- Fixed text between tool uses disappearing when not using streaming
|
||||
- Fixed duplicate sessions when resuming in VS Code extension
|
||||
- Improved heredoc delimiter parsing to prevent command smuggling
|
||||
- Blocked writes to `.claude/skills` directory in sandbox mode
|
||||
|
||||
## 2.1.37
|
||||
|
||||
- Fixed an issue where /fast was not immediately available after enabling /extra-usage
|
||||
|
||||
## 2.1.36
|
||||
|
||||
- Fast mode is now available for Opus 4.6. Learn more at https://code.claude.com/docs/en/fast-mode
|
||||
|
||||
## 2.1.34
|
||||
|
||||
- Fixed a crash when agent teams setting changed between renders
|
||||
- Fixed a bug where commands excluded from sandboxing (via `sandbox.excludedCommands` or `dangerouslyDisableSandbox`) could bypass the Bash ask permission rule when `autoAllowBashIfSandboxed` was enabled
|
||||
|
||||
## 2.1.33
|
||||
|
||||
- Fixed agent teammate sessions in tmux to send and receive messages
|
||||
- Fixed warnings about agent teams not being available on your current plan
|
||||
- Added `TeammateIdle` and `TaskCompleted` hook events for multi-agent workflows
|
||||
- Added support for restricting which sub-agents can be spawned via `Task(agent_type)` syntax in agent "tools" frontmatter
|
||||
- Added `memory` frontmatter field support for agents, enabling persistent memory with `user`, `project`, or `local` scope
|
||||
- Added plugin name to skill descriptions and `/skills` menu for better discoverability
|
||||
- Fixed an issue where submitting a new message while the model was in extended thinking would interrupt the thinking phase
|
||||
- Fixed an API error that could occur when aborting mid-stream, where whitespace text combined with a thinking block would bypass normalization and produce an invalid request
|
||||
- Fixed API proxy compatibility issue where 404 errors on streaming endpoints no longer triggered non-streaming fallback
|
||||
- Fixed an issue where proxy settings configured via `settings.json` environment variables were not applied to WebFetch and other HTTP requests on the Node.js build
|
||||
- Fixed `/resume` session picker showing raw XML markup instead of clean titles for sessions started with slash commands
|
||||
- Improved error messages for API connection failures — now shows specific cause (e.g., ECONNREFUSED, SSL errors) instead of generic "Connection error"
|
||||
- Errors from invalid managed settings are now surfaced
|
||||
- VSCode: Added support for remote sessions, allowing OAuth users to browse and resume sessions from claude.ai
|
||||
- VSCode: Added git branch and message count to the session picker, with support for searching by branch name
|
||||
- VSCode: Fixed scroll-to-bottom under-scrolling on initial session load and session switch
|
||||
|
||||
## 2.1.32
|
||||
|
||||
- Claude Opus 4.6 is now available!
|
||||
- Added research preview agent teams feature for multi-agent collaboration (token-intensive feature, requires setting CLAUDE_CODE_EXPERIMENTAL_AGENT_TEAMS=1)
|
||||
- Claude now automatically records and recalls memories as it works
|
||||
- Added "Summarize from here" to the message selector, allowing partial conversation summarization.
|
||||
- Skills defined in `.claude/skills/` within additional directories (`--add-dir`) are now loaded automatically.
|
||||
- Fixed `@` file completion showing incorrect relative paths when running from a subdirectory
|
||||
- Updated --resume to re-use --agent value specified in previous conversation by default.
|
||||
- Fixed: Bash tool no longer throws "Bad substitution" errors when heredocs contain JavaScript template literals like `${index + 1}`, which previously interrupted tool execution
|
||||
- Skill character budget now scales with context window (2% of context), so users with larger context windows can see more skill descriptions without truncation
|
||||
- Fixed Thai/Lao spacing vowels (สระ า, ำ) not rendering correctly in the input field
|
||||
- VSCode: Fixed slash commands incorrectly being executed when pressing Enter with preceding text in the input field
|
||||
- VSCode: Added spinner when loading past conversations list
|
||||
|
||||
## 2.1.31
|
||||
|
||||
- Added session resume hint on exit, showing how to continue your conversation later
|
||||
- Added support for full-width (zenkaku) space input from Japanese IME in checkbox selection
|
||||
- Fixed PDF too large errors permanently locking up sessions, requiring users to start a new conversation
|
||||
- Fixed bash commands incorrectly reporting failure with "Read-only file system" errors when sandbox mode was enabled
|
||||
- Fixed a crash that made sessions unusable after entering plan mode when project config in `~/.claude.json` was missing default fields
|
||||
- Fixed `temperatureOverride` being silently ignored in the streaming API path, causing all streaming requests to use the default temperature (1) regardless of the configured override
|
||||
- Fixed LSP shutdown/exit compatibility with strict language servers that reject null params
|
||||
- Improved system prompts to more clearly guide the model toward using dedicated tools (Read, Edit, Glob, Grep) instead of bash equivalents (`cat`, `sed`, `grep`, `find`), reducing unnecessary bash command usage
|
||||
- Improved PDF and request size error messages to show actual limits (100 pages, 20MB)
|
||||
- Reduced layout jitter in the terminal when the spinner appears and disappears during streaming
|
||||
- Removed misleading Anthropic API pricing from model selector for third-party provider (Bedrock, Vertex, Foundry) users
|
||||
|
||||
## 2.1.30
|
||||
|
||||
- Added `pages` parameter to the Read tool for PDFs, allowing specific page ranges to be read (e.g., `pages: "1-5"`). Large PDFs (>10 pages) now return a lightweight reference when `@` mentioned instead of being inlined into context.
|
||||
- Added pre-configured OAuth client credentials for MCP servers that don't support Dynamic Client Registration (e.g., Slack). Use `--client-id` and `--client-secret` with `claude mcp add`.
|
||||
- Added `/debug` for Claude to help troubleshoot the current session
|
||||
- Added support for additional `git log` and `git show` flags in read-only mode (e.g., `--topo-order`, `--cherry-pick`, `--format`, `--raw`)
|
||||
- Added token count, tool uses, and duration metrics to Task tool results
|
||||
- Added reduced motion mode to the config
|
||||
- Fixed phantom "(no content)" text blocks appearing in API conversation history, reducing token waste and potential model confusion
|
||||
- Fixed prompt cache not correctly invalidating when tool descriptions or input schemas changed, only when tool names changed
|
||||
- Fixed 400 errors that could occur after running `/login` when the conversation contained thinking blocks
|
||||
- Fixed a hang when resuming sessions with corrupted transcript files containing `parentUuid` cycles
|
||||
- Fixed rate limit message showing incorrect "/upgrade" suggestion for Max 20x users when extra-usage is unavailable
|
||||
- Fixed permission dialogs stealing focus while actively typing
|
||||
- Fixed subagents not being able to access SDK-provided MCP tools because they were not synced to the shared application state
|
||||
- Fixed a regression where Windows users with a `.bashrc` file could not run bash commands
|
||||
- Improved memory usage for `--resume` (68% reduction for users with many sessions) by replacing the session index with lightweight stat-based loading and progressive enrichment
|
||||
- Improved `TaskStop` tool to display the stopped command/task description in the result line instead of a generic "Task stopped" message
|
||||
- Changed `/model` to execute immediately instead of being queued
|
||||
- [VSCode] Added multiline input support to the "Other" text input in question dialogs (use Shift+Enter for new lines)
|
||||
- [VSCode] Fixed duplicate sessions appearing in the session list when starting a new conversation
|
||||
|
||||
## 2.1.29
|
||||
|
||||
- Fixed startup performance issues when resuming sessions that have `saved_hook_context`
|
||||
|
||||
## 2.1.27
|
||||
|
||||
- Added tool call failures and denials to debug logs
|
||||
- Fixed context management validation error for gateway users, ensuring `CLAUDE_CODE_DISABLE_EXPERIMENTAL_BETAS=1` avoids the error
|
||||
- Added `--from-pr` flag to resume sessions linked to a specific GitHub PR number or URL
|
||||
- Sessions are now automatically linked to PRs when created via `gh pr create`
|
||||
- Fixed /context command not displaying colored output
|
||||
- Fixed status bar duplicating background task indicator when PR status was shown
|
||||
- Windows: Fixed bash command execution failing for users with `.bashrc` files
|
||||
- Windows: Fixed console windows flashing when spawning child processes
|
||||
- VSCode: Fixed OAuth token expiration causing 401 errors after extended sessions
|
||||
|
||||
## 2.1.25
|
||||
|
||||
- Fixed beta header validation error for gateway users on Bedrock and Vertex, ensuring `CLAUDE_CODE_DISABLE_EXPERIMENTAL_BETAS=1` avoids the error
|
||||
|
||||
## 2.1.23
|
||||
|
||||
- Added customizable spinner verbs setting (`spinnerVerbs`)
|
||||
- Fixed mTLS and proxy connectivity for users behind corporate proxies or using client certificates
|
||||
- Fixed per-user temp directory isolation to prevent permission conflicts on shared systems
|
||||
- Fixed a race condition that could cause 400 errors when prompt caching scope was enabled
|
||||
- Fixed pending async hooks not being cancelled when headless streaming sessions ended
|
||||
- Fixed tab completion not updating the input field when accepting a suggestion
|
||||
- Fixed ripgrep search timeouts silently returning empty results instead of reporting errors
|
||||
- Improved terminal rendering performance with optimized screen data layout
|
||||
- Changed Bash commands to show timeout duration alongside elapsed time
|
||||
- Changed merged pull requests to show a purple status indicator in the prompt footer
|
||||
- [IDE] Fixed model options displaying incorrect region strings for Bedrock users in headless mode
|
||||
|
||||
## 2.1.22
|
||||
|
||||
- Fixed structured outputs for non-interactive (-p) mode
|
||||
|
||||
## 2.1.21
|
||||
|
||||
- Added support for full-width (zenkaku) number input from Japanese IME in option selection prompts
|
||||
- Fixed shell completion cache files being truncated on exit
|
||||
- Fixed API errors when resuming sessions that were interrupted during tool execution
|
||||
- Fixed auto-compact triggering too early on models with large output token limits
|
||||
- Fixed task IDs potentially being reused after deletion
|
||||
- Fixed file search not working in VS Code extension on Windows
|
||||
- Improved read/search progress indicators to show "Reading…" while in progress and "Read" when complete
|
||||
- Improved Claude to prefer file operation tools (Read, Edit, Write) over bash equivalents (cat, sed, awk)
|
||||
- [VSCode] Added automatic Python virtual environment activation, ensuring `python` and `pip` commands use the correct interpreter (configurable via `claudeCode.usePythonEnvironment` setting)
|
||||
- [VSCode] Fixed message action buttons having incorrect background colors
|
||||
|
||||
## 2.1.20
|
||||
|
||||
- Added arrow key history navigation in vim normal mode when cursor cannot move further
|
||||
- Added external editor shortcut (Ctrl+G) to the help menu for better discoverability
|
||||
- Added PR review status indicator to the prompt footer, showing the current branch's PR state (approved, changes requested, pending, or draft) as a colored dot with a clickable link
|
||||
- Added support for loading `CLAUDE.md` files from additional directories specified via `--add-dir` flag (requires setting `CLAUDE_CODE_ADDITIONAL_DIRECTORIES_CLAUDE_MD=1`)
|
||||
- Added ability to delete tasks via the `TaskUpdate` tool
|
||||
- Fixed session compaction issues that could cause resume to load full history instead of the compact summary
|
||||
- Fixed agents sometimes ignoring user messages sent while actively working on a task
|
||||
- Fixed wide character (emoji, CJK) rendering artifacts where trailing columns were not cleared when replaced by narrower characters
|
||||
- Fixed JSON parsing errors when MCP tool responses contain special Unicode characters
|
||||
- Fixed up/down arrow keys in multi-line and wrapped text input to prioritize cursor movement over history navigation
|
||||
- Fixed draft prompt being lost when pressing UP arrow to navigate command history
|
||||
- Fixed ghost text flickering when typing slash commands mid-input
|
||||
- Fixed marketplace source removal not properly deleting settings
|
||||
- Fixed duplicate output in some commands like `/context`
|
||||
- Fixed task list sometimes showing outside the main conversation view
|
||||
- Fixed syntax highlighting for diffs occurring within multiline constructs like Python docstrings
|
||||
- Fixed crashes when cancelling tool use
|
||||
- Improved `/sandbox` command UI to show dependency status with installation instructions when dependencies are missing
|
||||
- Improved thinking status text with a subtle shimmer animation
|
||||
- Improved task list to dynamically adjust visible items based on terminal height
|
||||
- Improved fork conversation hint to show how to resume the original session
|
||||
- Changed collapsed read/search groups to show present tense ("Reading", "Searching for") while in progress, and past tense ("Read", "Searched for") when complete
|
||||
- Changed `ToolSearch` results to appear as a brief notification instead of inline in the conversation
|
||||
- Changed the `/commit-push-pr` skill to automatically post PR URLs to Slack channels when configured via MCP tools
|
||||
- Changed the `/copy` command to be available to all users
|
||||
- Changed background agents to prompt for tool permissions before launching
|
||||
- Changed permission rules like `Bash(*)` to be accepted and treated as equivalent to `Bash`
|
||||
- Changed config backups to be timestamped and rotated (keeping 5 most recent) to prevent data loss
|
||||
|
||||
## 2.1.19
|
||||
|
||||
- Added env var `CLAUDE_CODE_ENABLE_TASKS`, set to `false` to keep the old system temporarily
|
||||
- Added shorthand `$0`, `$1`, etc. for accessing individual arguments in custom commands
|
||||
- Fixed crashes on processors without AVX instruction support
|
||||
- Fixed dangling Claude Code processes when terminal is closed by catching EIO errors from `process.exit()` and using SIGKILL as fallback
|
||||
- Fixed `/rename` and `/tag` not updating the correct session when resuming from a different directory (e.g., git worktrees)
|
||||
- Fixed resuming sessions by custom title not working when run from a different directory
|
||||
- Fixed pasted text content being lost when using prompt stash (Ctrl+S) and restore
|
||||
- Fixed agent list displaying "Sonnet (default)" instead of "Inherit (default)" for agents without an explicit model setting
|
||||
- Fixed backgrounded hook commands not returning early, potentially causing the session to wait on a process that was intentionally backgrounded
|
||||
- Fixed file write preview omitting empty lines
|
||||
- Changed skills without additional permissions or hooks to be allowed without requiring approval
|
||||
- Changed indexed argument syntax from `$ARGUMENTS.0` to `$ARGUMENTS[0]` (bracket syntax)
|
||||
- [SDK] Added replay of `queued_command` attachment messages as `SDKUserMessageReplay` events when `replayUserMessages` is enabled
|
||||
- [VSCode] Enabled session forking and rewind functionality for all users
|
||||
|
||||
## 2.1.18
|
||||
|
||||
- Added customizable keyboard shortcuts. Configure keybindings per context, create chord sequences, and personalize your workflow. Run `/keybindings` to get started. Learn more at https://code.claude.com/docs/en/keybindings
|
||||
|
||||
## 2.1.17
|
||||
|
||||
- Fixed crashes on processors without AVX instruction support
|
||||
|
||||
## 2.1.16
|
||||
|
||||
- Added new task management system, including new capabilities like dependency tracking
|
||||
- [VSCode] Added native plugin management support
|
||||
- [VSCode] Added ability for OAuth users to browse and resume remote Claude sessions from the Sessions dialog
|
||||
- Fixed out-of-memory crashes when resuming sessions with heavy subagent usage
|
||||
- Fixed an issue where the "context remaining" warning was not hidden after running `/compact`
|
||||
- Fixed session titles on the resume screen not respecting the user's language setting
|
||||
- [IDE] Fixed a race condition on Windows where the Claude Code sidebar view container would not appear on start
|
||||
|
||||
## 2.1.15
|
||||
|
||||
- Added deprecation notification for npm installations - run `claude install` or see https://docs.anthropic.com/en/docs/claude-code/getting-started for more options
|
||||
- Improved UI rendering performance with React Compiler
|
||||
- Fixed the "Context left until auto-compact" warning not disappearing after running `/compact`
|
||||
- Fixed MCP stdio server timeout not killing child process, which could cause UI freezes
|
||||
|
||||
## 2.1.14
|
||||
|
||||
- Added history-based autocomplete in bash mode (`!`) - type a partial command and press Tab to complete from your bash command history
|
||||
- Added search to installed plugins list - type to filter by name or description
|
||||
- Added support for pinning plugins to specific git commit SHAs, allowing marketplace entries to install exact versions
|
||||
- Fixed a regression where the context window blocking limit was calculated too aggressively, blocking users at ~65% context usage instead of the intended ~98%
|
||||
- Fixed memory issues that could cause crashes when running parallel subagents
|
||||
- Fixed memory leak in long-running sessions where stream resources were not cleaned up after shell commands completed
|
||||
- Fixed `@` symbol incorrectly triggering file autocomplete suggestions in bash mode
|
||||
- Fixed `@`-mention menu folder click behavior to navigate into directories instead of selecting them
|
||||
- Fixed `/feedback` command generating invalid GitHub issue URLs when description is very long
|
||||
- Fixed `/context` command to show the same token count and percentage as the status line in verbose mode
|
||||
- Fixed an issue where `/config`, `/context`, `/model`, and `/todos` command overlays could close unexpectedly
|
||||
- Fixed slash command autocomplete selecting wrong command when typing similar commands (e.g., `/context` vs `/compact`)
|
||||
- Fixed inconsistent back navigation in plugin marketplace when only one marketplace is configured
|
||||
- Fixed iTerm2 progress bar not clearing properly on exit, preventing lingering indicators and bell sounds
|
||||
- Improved backspace to delete pasted text as a single token instead of one character at a time
|
||||
- [VSCode] Added `/usage` command to display current plan usage
|
||||
|
||||
## 2.1.12
|
||||
|
||||
- Fixed message rendering bug
|
||||
|
||||
## 2.1.11
|
||||
|
||||
- Fixed excessive MCP connection requests for HTTP/SSE transports
|
||||
|
||||
## 2.1.10
|
||||
|
||||
- Added new `Setup` hook event that can be triggered via `--init`, `--init-only`, or `--maintenance` CLI flags for repository setup and maintenance operations
|
||||
- Added keyboard shortcut 'c' to copy OAuth URL when browser doesn't open automatically during login
|
||||
- Fixed a crash when running bash commands containing heredocs with JavaScript template literals like `${index + 1}`
|
||||
- Improved startup to capture keystrokes typed before the REPL is fully ready
|
||||
- Improved file suggestions to show as removable attachments instead of inserting text when accepted
|
||||
- [VSCode] Added install count display to plugin listings
|
||||
- [VSCode] Added trust warning when installing plugins
|
||||
|
||||
## 2.1.9
|
||||
|
||||
- Added `auto:N` syntax for configuring the MCP tool search auto-enable threshold, where N is the context window percentage (0-100)
|
||||
- Added `plansDirectory` setting to customize where plan files are stored
|
||||
- Added external editor support (Ctrl+G) in AskUserQuestion "Other" input field
|
||||
- Added session URL attribution to commits and PRs created from web sessions
|
||||
- Added support for `PreToolUse` hooks to return `additionalContext` to the model
|
||||
- Added `${CLAUDE_SESSION_ID}` string substitution for skills to access the current session ID
|
||||
- Fixed long sessions with parallel tool calls failing with an API error about orphan tool_result blocks
|
||||
- Fixed MCP server reconnection hanging when cached connection promise never resolves
|
||||
- Fixed Ctrl+Z suspend not working in terminals using Kitty keyboard protocol (Ghostty, iTerm2, kitty, WezTerm)
|
||||
|
||||
## 2.1.7
|
||||
|
||||
- Added `showTurnDuration` setting to hide turn duration messages (e.g., "Cooked for 1m 6s")
|
||||
@@ -252,7 +518,7 @@
|
||||
- Added loading indicator when resuming conversations for better feedback
|
||||
- Fixed `/context` command not respecting custom system prompts in non-interactive mode
|
||||
- Fixed order of consecutive Ctrl+K lines when pasting with Ctrl+Y
|
||||
- Improved @ mention file suggestion speed (~3x faster in git repositories)
|
||||
- Improved @ mention file suggestion speed (~3× faster in git repositories)
|
||||
- Improved file suggestion performance in repos with `.ignore` or `.rgignore` files
|
||||
- Improved settings validation errors to be more prominent
|
||||
- Changed thinking toggle from Tab to Alt+T to avoid accidental triggers
|
||||
|
||||
31
examples/settings/README.md
Normal file
31
examples/settings/README.md
Normal file
@@ -0,0 +1,31 @@
|
||||
# Settings Examples
|
||||
|
||||
Example Claude Code settings files, primarily intended for organization-wide deployments. Use these are starting points — adjust them to fit your needs.
|
||||
|
||||
These may be applied at any level of the [settings hierarchy](https://code.claude.com/docs/en/settings#settings-files), though certain properties only take effect if specified in enterprise settings (e.g. `strictKnownMarketplaces`, `allowManagedHooksOnly`, `allowManagedPermissionRulesOnly`).
|
||||
|
||||
|
||||
## Configuration Examples
|
||||
|
||||
> [!WARNING]
|
||||
> These examples are community-maintained snippets which may be unsupported or incorrect. You are responsible for the correctness of your own settings configuration.
|
||||
|
||||
| Setting | [`settings-lax.json`](./settings-lax.json) | [`settings-strict.json`](./settings-strict.json) | [`settings-bash-sandbox.json`](./settings-bash-sandbox.json) |
|
||||
|---------|:---:|:---:|:---:|
|
||||
| Disable `--dangerously-skip-permissions` | ✅ | ✅ | |
|
||||
| Block plugin marketplaces | ✅ | ✅ | |
|
||||
| Block user and project-defined permission `allow` / `ask` / `deny` | | ✅ | ✅ |
|
||||
| Block user and project-defined hooks | | ✅ | |
|
||||
| Deny web fetch and search tools | | ✅ | |
|
||||
| Bash tool requires approval | | ✅ | |
|
||||
| Bash tool must run inside of sandbox | | | ✅ |
|
||||
|
||||
## Tips
|
||||
- Consider merging snippets of the above examples to reach your desired configuration
|
||||
- Settings files must be valid JSON
|
||||
- Before deploying configuration files to your organization, test them locally by applying to `managed-settings.json`, `settings.json` or `settings.local.json`
|
||||
- The `sandbox` property only applies to the `Bash` tool; it does not apply to other tools (like Read, Write, WebSearch, WebFetch, MCPs), hooks, or internal commands
|
||||
|
||||
## Full Documentation
|
||||
|
||||
See https://code.claude.com/docs/en/settings for complete documentation on all available managed settings.
|
||||
18
examples/settings/settings-bash-sandbox.json
Normal file
18
examples/settings/settings-bash-sandbox.json
Normal file
@@ -0,0 +1,18 @@
|
||||
{
|
||||
"allowManagedPermissionRulesOnly": true,
|
||||
"sandbox": {
|
||||
"enabled": true,
|
||||
"autoAllowBashIfSandboxed": false,
|
||||
"allowUnsandboxedCommands": false,
|
||||
"excludedCommands": [],
|
||||
"network": {
|
||||
"allowUnixSockets": [],
|
||||
"allowAllUnixSockets": false,
|
||||
"allowLocalBinding": false,
|
||||
"allowedDomains": [],
|
||||
"httpProxyPort": null,
|
||||
"socksProxyPort": null
|
||||
},
|
||||
"enableWeakerNestedSandbox": false
|
||||
}
|
||||
}
|
||||
6
examples/settings/settings-lax.json
Normal file
6
examples/settings/settings-lax.json
Normal file
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"permissions": {
|
||||
"disableBypassPermissionsMode": "disable"
|
||||
},
|
||||
"strictKnownMarketplaces": []
|
||||
}
|
||||
28
examples/settings/settings-strict.json
Normal file
28
examples/settings/settings-strict.json
Normal file
@@ -0,0 +1,28 @@
|
||||
{
|
||||
"permissions": {
|
||||
"disableBypassPermissionsMode": "disable",
|
||||
"ask": [
|
||||
"Bash"
|
||||
],
|
||||
"deny": [
|
||||
"WebSearch",
|
||||
"WebFetch"
|
||||
]
|
||||
},
|
||||
"allowManagedPermissionRulesOnly": true,
|
||||
"allowManagedHooksOnly": true,
|
||||
"strictKnownMarketplaces": [],
|
||||
"sandbox": {
|
||||
"autoAllowBashIfSandboxed": false,
|
||||
"excludedCommands": [],
|
||||
"network": {
|
||||
"allowUnixSockets": [],
|
||||
"allowAllUnixSockets": false,
|
||||
"allowLocalBinding": false,
|
||||
"allowedDomains": [],
|
||||
"httpProxyPort": null,
|
||||
"socksProxyPort": null
|
||||
},
|
||||
"enableWeakerNestedSandbox": false
|
||||
}
|
||||
}
|
||||
@@ -25,6 +25,7 @@ Learn more in the [official plugins documentation](https://docs.claude.com/en/do
|
||||
| [pr-review-toolkit](./pr-review-toolkit/) | Comprehensive PR review agents specializing in comments, tests, error handling, type design, code quality, and code simplification | **Command:** `/pr-review-toolkit:review-pr` - Run with optional review aspects (comments, tests, errors, types, code, simplify, all)<br>**Agents:** `comment-analyzer`, `pr-test-analyzer`, `silent-failure-hunter`, `type-design-analyzer`, `code-reviewer`, `code-simplifier` |
|
||||
| [ralph-wiggum](./ralph-wiggum/) | Interactive self-referential AI loops for iterative development. Claude works on the same task repeatedly until completion | **Commands:** `/ralph-loop`, `/cancel-ralph` - Start/stop autonomous iteration loops<br>**Hook:** Stop - Intercepts exit attempts to continue iteration |
|
||||
| [security-guidance](./security-guidance/) | Security reminder hook that warns about potential security issues when editing files | **Hook:** PreToolUse - Monitors 9 security patterns including command injection, XSS, eval usage, dangerous HTML, pickle deserialization, and os.system calls |
|
||||
| [slack-quote-formatter](./slack-quote-formatter/) | Enhances visual display of Slack forwarded and quoted messages with distinctive Unicode box formatting | **Hook:** UserPromptSubmit - Transforms `[Forwarded Message]` blocks into visually distinctive formatted boxes with clear boundaries and indentation |
|
||||
|
||||
## Installation
|
||||
|
||||
|
||||
@@ -6,7 +6,7 @@ description: Code review a pull request
|
||||
Provide a code review for the given pull request.
|
||||
|
||||
**Agent assumptions (applies to all agents and subagents):**
|
||||
- All tools are functional and will work without error. Do not test tools or make exploratory calls.
|
||||
- All tools are functional and will work without error. Do not test tools or make exploratory calls. Make sure this is clear to every subagent that is launched.
|
||||
- Only call a tool if it is required to complete the task. Every tool call should have a clear purpose.
|
||||
|
||||
To do this, follow these steps precisely:
|
||||
@@ -61,10 +61,13 @@ Note: Still review Claude generated PR's.
|
||||
If NO issues were found, post a summary comment using `gh pr comment` (if `--comment` argument is provided):
|
||||
"No issues found. Checked for bugs and CLAUDE.md compliance."
|
||||
|
||||
8. Post inline comments for each issue using `mcp__github_inline_comment__create_inline_comment`. For each comment:
|
||||
8. Create a list of all comments that you plan on leaving. This is only for you to make sure you are comfortable with the comments. Do not post this list anywhere.
|
||||
|
||||
9. Post inline comments for each issue using `mcp__github_inline_comment__create_inline_comment`. For each comment:
|
||||
- Provide a brief description of the issue
|
||||
- For small, self-contained fixes, include a committable suggestion block
|
||||
- For larger fixes (6+ lines, structural changes, or changes spanning multiple locations), describe the issue and suggested fix without a suggestion block
|
||||
- Never post a committable suggestion UNLESS committing the suggestion fixes the issue entirely. If follow up steps are required, do not leave a committable suggestion.
|
||||
|
||||
**IMPORTANT: Only post ONE comment per unique issue. Do not post duplicate comments.**
|
||||
|
||||
|
||||
18
plugins/slack-quote-formatter/.claude-plugin/plugin.json
Normal file
18
plugins/slack-quote-formatter/.claude-plugin/plugin.json
Normal file
@@ -0,0 +1,18 @@
|
||||
{
|
||||
"name": "slack-quote-formatter",
|
||||
"version": "1.0.0",
|
||||
"description": "Enhances visual display of Slack forwarded and quoted messages with distinctive formatting",
|
||||
"author": {
|
||||
"name": "Anthropic",
|
||||
"email": "support@anthropic.com"
|
||||
},
|
||||
"license": "MIT",
|
||||
"keywords": [
|
||||
"slack",
|
||||
"formatting",
|
||||
"quotes",
|
||||
"messages",
|
||||
"visual"
|
||||
],
|
||||
"hooks": "./hooks/hooks.json"
|
||||
}
|
||||
87
plugins/slack-quote-formatter/README.md
Normal file
87
plugins/slack-quote-formatter/README.md
Normal file
@@ -0,0 +1,87 @@
|
||||
# Slack Quote Formatter
|
||||
|
||||
Enhances the visual display of Slack forwarded and quoted messages with distinctive Unicode box formatting.
|
||||
|
||||
## Overview
|
||||
|
||||
When Claude Code receives messages from Slack that include forwarded messages, they typically appear as plain text:
|
||||
|
||||
```
|
||||
[Forwarded Message]
|
||||
From: Felix Klock
|
||||
Message: I assume it would be a matter of reviewing the entries...
|
||||
```
|
||||
|
||||
This plugin transforms these plain blocks into visually distinctive formatted quotes:
|
||||
|
||||
```
|
||||
╔════════════════════════════════════════════════════════════════════╗
|
||||
║ FORWARDED MESSAGE ║
|
||||
╠════════════════════════════════════════════════════════════════════╣
|
||||
║ From: Felix Klock ║
|
||||
╟────────────────────────────────────────────────────────────────────╢
|
||||
║ I assume it would be a matter of reviewing the entries... ║
|
||||
╚════════════════════════════════════════════════════════════════════╝
|
||||
```
|
||||
|
||||
## Features
|
||||
|
||||
- Unicode box drawing characters for clear visual boundaries
|
||||
- Distinct header section highlighting "FORWARDED MESSAGE"
|
||||
- Sender information prominently displayed
|
||||
- Message content indented for quote-like appearance
|
||||
- Automatic text wrapping for long messages
|
||||
- Handles multiple forwarded messages in a single prompt
|
||||
|
||||
## Installation
|
||||
|
||||
This plugin is included in the Claude Code plugins repository. To enable it:
|
||||
|
||||
1. Add the plugin to your project's `.claude/settings.json`:
|
||||
```json
|
||||
{
|
||||
"plugins": [
|
||||
"path/to/plugins/slack-quote-formatter"
|
||||
]
|
||||
}
|
||||
```
|
||||
|
||||
2. Or install via the Claude Code plugin command:
|
||||
```
|
||||
/plugin add slack-quote-formatter
|
||||
```
|
||||
|
||||
## How It Works
|
||||
|
||||
The plugin registers a `UserPromptSubmit` hook that:
|
||||
|
||||
1. Intercepts incoming prompts
|
||||
2. Detects `[Forwarded Message]` blocks in the Slack context
|
||||
3. Transforms them into formatted boxes with visual distinction
|
||||
4. Passes the transformed prompt to Claude
|
||||
|
||||
## Configuration
|
||||
|
||||
No configuration required. The plugin automatically activates when Slack forwarded messages are detected.
|
||||
|
||||
## Plugin Structure
|
||||
|
||||
```
|
||||
slack-quote-formatter/
|
||||
├── .claude-plugin/
|
||||
│ └── plugin.json # Plugin metadata
|
||||
├── hooks/
|
||||
│ ├── hooks.json # Hook configuration
|
||||
│ └── format_slack_quotes.py # Transformation logic
|
||||
└── README.md
|
||||
```
|
||||
|
||||
## Why Visual Distinction Matters
|
||||
|
||||
When working with Slack context in Claude Code, quoted messages can easily blend into the surrounding text, making it harder to:
|
||||
|
||||
- Identify what content is quoted vs. original
|
||||
- Understand the source of different pieces of information
|
||||
- Parse complex threads with multiple forwarded messages
|
||||
|
||||
This plugin makes quoted content immediately recognizable, improving readability and reducing confusion.
|
||||
185
plugins/slack-quote-formatter/hooks/format_slack_quotes.py
Executable file
185
plugins/slack-quote-formatter/hooks/format_slack_quotes.py
Executable file
@@ -0,0 +1,185 @@
|
||||
#!/usr/bin/env python3
|
||||
"""
|
||||
Slack Quote Formatter - UserPromptSubmit Hook
|
||||
|
||||
Transforms plain Slack forwarded/quoted messages into visually distinctive
|
||||
formatted blocks with Unicode box characters and better layout.
|
||||
|
||||
Before:
|
||||
[Forwarded Message]
|
||||
From: John Doe
|
||||
Message: Here is some text...
|
||||
|
||||
After:
|
||||
╔═══════════════════════════════════════════════════════════╗
|
||||
║ FORWARDED MESSAGE ║
|
||||
╠═══════════════════════════════════════════════════════════╣
|
||||
║ From: John Doe ║
|
||||
╟───────────────────────────────────────────────────────────╢
|
||||
║ Here is some text... ║
|
||||
╚═══════════════════════════════════════════════════════════╝
|
||||
"""
|
||||
|
||||
import json
|
||||
import re
|
||||
import sys
|
||||
|
||||
|
||||
def format_forwarded_message(from_line: str, message_content: str) -> str:
|
||||
"""Format a single forwarded message with visual box styling."""
|
||||
|
||||
# Box drawing characters
|
||||
TOP_LEFT = "╔"
|
||||
TOP_RIGHT = "╗"
|
||||
BOTTOM_LEFT = "╚"
|
||||
BOTTOM_RIGHT = "╝"
|
||||
HORIZONTAL = "═"
|
||||
VERTICAL = "║"
|
||||
LEFT_T = "╠"
|
||||
RIGHT_T = "╣"
|
||||
LEFT_LIGHT = "╟"
|
||||
RIGHT_LIGHT = "╢"
|
||||
LIGHT_HORIZONTAL = "─"
|
||||
|
||||
# Configuration
|
||||
BOX_WIDTH = 70
|
||||
INNER_WIDTH = BOX_WIDTH - 4 # Account for "║ " and " ║"
|
||||
|
||||
def pad_line(text: str, width: int = INNER_WIDTH) -> str:
|
||||
"""Pad a line to fill the box width."""
|
||||
if len(text) > width:
|
||||
return text[:width]
|
||||
return text + " " * (width - len(text))
|
||||
|
||||
def wrap_text(text: str, width: int) -> list:
|
||||
"""Wrap text to fit within the specified width."""
|
||||
words = text.split()
|
||||
lines = []
|
||||
current_line = []
|
||||
current_length = 0
|
||||
|
||||
for word in words:
|
||||
word_len = len(word)
|
||||
if current_length + word_len + (1 if current_line else 0) <= width:
|
||||
current_line.append(word)
|
||||
current_length += word_len + (1 if len(current_line) > 1 else 0)
|
||||
else:
|
||||
if current_line:
|
||||
lines.append(" ".join(current_line))
|
||||
current_line = [word]
|
||||
current_length = word_len
|
||||
|
||||
if current_line:
|
||||
lines.append(" ".join(current_line))
|
||||
|
||||
return lines if lines else [""]
|
||||
|
||||
lines = []
|
||||
|
||||
# Top border with header
|
||||
lines.append(f"{TOP_LEFT}{HORIZONTAL * (BOX_WIDTH - 2)}{TOP_RIGHT}")
|
||||
|
||||
# Header line
|
||||
header = "FORWARDED MESSAGE"
|
||||
lines.append(f"{VERTICAL} {pad_line(header)}{VERTICAL}")
|
||||
|
||||
# Separator after header
|
||||
lines.append(f"{LEFT_T}{HORIZONTAL * (BOX_WIDTH - 2)}{RIGHT_T}")
|
||||
|
||||
# From line
|
||||
from_display = from_line.strip()
|
||||
lines.append(f"{VERTICAL} {pad_line(from_display)}{VERTICAL}")
|
||||
|
||||
# Light separator before message
|
||||
lines.append(f"{LEFT_LIGHT}{LIGHT_HORIZONTAL * (BOX_WIDTH - 2)}{RIGHT_LIGHT}")
|
||||
|
||||
# Message content (indented and wrapped)
|
||||
message_lines = message_content.strip().split("\n")
|
||||
for msg_line in message_lines:
|
||||
# Handle each line, wrapping if necessary
|
||||
wrapped = wrap_text(msg_line, INNER_WIDTH - 2) # Extra indent
|
||||
for wrapped_line in wrapped:
|
||||
indented = " " + wrapped_line # Add indent for quote appearance
|
||||
lines.append(f"{VERTICAL} {pad_line(indented)}{VERTICAL}")
|
||||
|
||||
# Bottom border
|
||||
lines.append(f"{BOTTOM_LEFT}{HORIZONTAL * (BOX_WIDTH - 2)}{BOTTOM_RIGHT}")
|
||||
|
||||
return "\n".join(lines)
|
||||
|
||||
|
||||
def transform_slack_context(text: str) -> str:
|
||||
"""
|
||||
Find and transform [Forwarded Message] blocks in the text.
|
||||
|
||||
Matches patterns like:
|
||||
[Forwarded Message]
|
||||
From: Name Here
|
||||
Message: Content here that may span
|
||||
multiple lines until we hit the next section
|
||||
"""
|
||||
|
||||
# Pattern to match forwarded message blocks
|
||||
# This handles the common format from Slack context
|
||||
pattern = r'\[Forwarded Message\]\s*\n\s*From:\s*([^\n]+)\s*\nMessage:\s*(.+?)(?=\n\s*\[|\n\[pnkfelix\]|\n<|\Z)'
|
||||
|
||||
def replace_match(match):
|
||||
from_name = match.group(1).strip()
|
||||
message = match.group(2).strip()
|
||||
|
||||
formatted = format_forwarded_message(f"From: {from_name}", message)
|
||||
return f"\n{formatted}\n"
|
||||
|
||||
# Apply transformation
|
||||
result = re.sub(pattern, replace_match, text, flags=re.DOTALL)
|
||||
|
||||
return result
|
||||
|
||||
|
||||
def main():
|
||||
"""Main entry point for the UserPromptSubmit hook."""
|
||||
try:
|
||||
# Read input from stdin
|
||||
input_data = json.load(sys.stdin)
|
||||
|
||||
# Get the user prompt if available
|
||||
user_prompt = input_data.get("user_prompt", "")
|
||||
|
||||
if not user_prompt:
|
||||
# No prompt to transform, just pass through
|
||||
print(json.dumps({}))
|
||||
sys.exit(0)
|
||||
|
||||
# Check if there are forwarded messages to format
|
||||
if "[Forwarded Message]" not in user_prompt:
|
||||
# Nothing to transform
|
||||
print(json.dumps({}))
|
||||
sys.exit(0)
|
||||
|
||||
# Transform the prompt
|
||||
transformed_prompt = transform_slack_context(user_prompt)
|
||||
|
||||
# If we made changes, return the transformed prompt
|
||||
if transformed_prompt != user_prompt:
|
||||
result = {
|
||||
"transformedPrompt": transformed_prompt
|
||||
}
|
||||
print(json.dumps(result))
|
||||
else:
|
||||
print(json.dumps({}))
|
||||
|
||||
except json.JSONDecodeError:
|
||||
# No valid JSON input, pass through
|
||||
print(json.dumps({}))
|
||||
except Exception as e:
|
||||
# Log error but don't block
|
||||
error_output = {
|
||||
"systemMessage": f"[slack-quote-formatter] Warning: {str(e)}"
|
||||
}
|
||||
print(json.dumps(error_output))
|
||||
|
||||
sys.exit(0)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
14
plugins/slack-quote-formatter/hooks/hooks.json
Normal file
14
plugins/slack-quote-formatter/hooks/hooks.json
Normal file
@@ -0,0 +1,14 @@
|
||||
{
|
||||
"UserPromptSubmit": [
|
||||
{
|
||||
"matcher": ".*",
|
||||
"hooks": [
|
||||
{
|
||||
"type": "command",
|
||||
"command": "python3 ${CLAUDE_PLUGIN_ROOT}/hooks/format_slack_quotes.py",
|
||||
"timeout": 5000
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
Reference in New Issue
Block a user