Common workflows

yes
Summary: Step-by-step guides for exploring codebases, fixing bugs, refactoring, testing, and other everyday tasks with Claude Code.

Editorial Notes

Editorial note: This is where theory meets practice. The workflow patterns here – debugging, refactoring, codebase exploration, test writing – are the bread and butter of daily Claude Code usage. Rather than reading this page end to end, treat it as a reference: skim the workflow names, then deep-dive into the ones relevant to your current work. Each workflow demonstrates how to frame a task so Claude can execute it effectively.


Original Documentation

Documentation Index#

Fetch the complete documentation index at: https://code.claude.com/docs/llms.txt Use this file to discover all available pages before exploring further.

Step-by-step guides for exploring codebases, fixing bugs, refactoring, testing, and other everyday tasks with Claude Code.

This page covers practical workflows for everyday development: exploring unfamiliar code, debugging, refactoring, writing tests, creating PRs, and managing sessions. Each section includes example prompts you can adapt to your own projects. For higher-level patterns and tips, see Best practices.

Understand new codebases#

Get a quick codebase overview#

Suppose you’ve just joined a new project and need to understand its structure quickly.

    cd /path/to/project 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Start Claude Code"></span>
```bash
    claude 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Ask for a high-level overview"></span>
> give me an overview of this codebase 
```

    > explain the main architecture patterns used here 
    ```
> what are the key data models?
```
    > how is authentication handled?
    ```
  <span class="step-end"></span>
<span class="steps-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * Start with broad questions, then narrow down to specific areas
  * Ask about coding conventions and patterns used in the project
  * Request a glossary of project-specific terms
<span class="callout-end"></span>

### Find relevant code

Suppose you need to locate code related to a specific feature or functionality.

<span class="steps-start"></span>
  <span class="step-marker" data-step-title="Ask Claude to find relevant files"></span>
> find the files that handle user authentication 
```

    > how do these authentication files work together? 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Understand the execution flow"></span>
> trace the login process from front-end to database 
```

Tips:

  • Be specific about what you’re looking for
  • Use domain language from the project
  • Install a code intelligence plugin for your language to give Claude precise “go to definition” and “find references” navigation

Fix bugs efficiently#

Suppose you’ve encountered an error message and need to find and fix its source.

    > I'm seeing an error when I run npm test 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Ask for fix recommendations"></span>
> suggest a few ways to fix the @ts-ignore in user.ts 
```

    > update user.ts to add the null check you suggested 
    ```
  <span class="step-end"></span>
<span class="steps-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * Tell Claude the command to reproduce the issue and get a stack trace
  * Mention any steps to reproduce the error
  * Let Claude know if the error is intermittent or consistent
<span class="callout-end"></span>

***

## Refactor code

Suppose you need to update old code to use modern patterns and practices.

<span class="steps-start"></span>
  <span class="step-marker" data-step-title="Identify legacy code for refactoring"></span>
> find deprecated API usage in our codebase 
```

    > suggest how to refactor utils.js to use modern JavaScript features 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Apply the changes safely"></span>
> refactor utils.js to use ES2024 features while maintaining the same behavior 
```

    > run tests for the refactored code 
    ```
  <span class="step-end"></span>
<span class="steps-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * Ask Claude to explain the benefits of the modern approach
  * Request that changes maintain backward compatibility when needed
  * Do refactoring in small, testable increments
<span class="callout-end"></span>

***

## Use specialized subagents

Suppose you want to use specialized AI subagents to handle specific tasks more effectively.

<span class="steps-start"></span>
  <span class="step-marker" data-step-title="View available subagents"></span>
> /agents
```

This shows all available subagents and lets you create new ones.

Claude Code automatically delegates appropriate tasks to specialized subagents:

    > review my recent code changes for security issues
    ```
> run all tests and fix any failures
```

    > use the code-reviewer subagent to check the auth module
    ```
> have the debugger subagent investigate why users can't log in
```

    > /agents
    ```

Then select "Create New subagent" and follow the prompts to define:

* A unique identifier that describes the subagent's purpose (for example, `code-reviewer`, `api-designer`).
* When Claude should use this agent
* Which tools it can access
* A system prompt describing the agent's role and behavior
  <span class="step-end"></span>
<span class="steps-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * Create project-specific subagents in `.claude/agents/` for team sharing
  * Use descriptive `description` fields to enable automatic delegation
  * Limit tool access to what each subagent actually needs
  * Check the [subagents documentation](/en/sub-agents) for detailed examples
<span class="callout-end"></span>

***

## Use Plan Mode for safe code analysis

Plan Mode instructs Claude to create a plan by analyzing the codebase with read-only operations, perfect for exploring codebases, planning complex changes, or reviewing code safely. In Plan Mode, Claude uses [`AskUserQuestion`](/en/settings#tools-available-to-claude) to gather requirements and clarify your goals before proposing a plan.

### When to use Plan Mode

* **Multi-step implementation**: When your feature requires making edits to many files
* **Code exploration**: When you want to research the codebase thoroughly before changing anything
* **Interactive development**: When you want to iterate on the direction with Claude

### How to use Plan Mode

**Turn on Plan Mode during a session**

You can switch into Plan Mode during a session using **Shift+Tab** to cycle through permission modes.

If you are in Normal Mode, **Shift+Tab** first switches into Auto-Accept Mode, indicated by `⏵⏵ accept edits on` at the bottom of the terminal. A subsequent **Shift+Tab** will switch into Plan Mode, indicated by `⏸ plan mode on`.

**Start a new session in Plan Mode**

To start a new session in Plan Mode, use the `--permission-mode plan` flag:

```bash
claude --permission-mode plan

Run “headless” queries in Plan Mode

You can also run a query in Plan Mode directly with -p (that is, in “headless mode”):

claude --permission-mode plan -p "Analyze the authentication system and suggest improvements"

Example: Planning a complex refactor#

claude --permission-mode plan
> I need to refactor our authentication system to use OAuth2. Create a detailed migration plan.

Claude analyzes the current implementation and create a comprehensive plan. Refine with follow-ups:

> What about backward compatibility?
> How should we handle database migration?

Press Ctrl+G to open the plan in your default text editor, where you can edit it directly before Claude proceeds.

Configure Plan Mode as default#

// .claude/settings.json
{
  "permissions": {
    "defaultMode": "plan"
  }
}

See settings documentation for more configuration options.


Work with tests#

Suppose you need to add tests for uncovered code.

    > find functions in NotificationsService.swift that are not covered by tests 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Generate test scaffolding"></span>
> add tests for the notification service 
```

    > add test cases for edge conditions in the notification service 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Run and verify tests"></span>
> run the new tests and fix any failures 
```

Claude can generate tests that follow your project’s existing patterns and conventions. When asking for tests, be specific about what behavior you want to verify. Claude examines your existing test files to match the style, frameworks, and assertion patterns already in use.

For comprehensive coverage, ask Claude to identify edge cases you might have missed. Claude can analyze your code paths and suggest tests for error conditions, boundary values, and unexpected inputs that are easy to overlook.


Create pull requests#

You can create pull requests by asking Claude directly (“create a pr for my changes”) or by using the /commit-push-pr skill, which commits, pushes, and opens a PR in one step.

> /commit-push-pr

If you have a Slack MCP server configured and specify channels in your CLAUDE.md (for example, “post PR URLs to #team-prs”), the skill automatically posts the PR URL to those channels.

For more control over the process, guide Claude through it step-by-step or create your own skill:

    > summarize the changes I've made to the authentication module
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Generate a pull request"></span>
> create a pr
```

    > enhance the PR description with more context about the security improvements
    ```
  <span class="step-end"></span>
<span class="steps-end"></span>

When you create a PR using `gh pr create`, the session is automatically linked to that PR. You can resume it later with `claude --from-pr <number>`.

<span class="callout-start" data-callout-type="tip"></span>
  Review Claude's generated PR before submitting and ask Claude to highlight potential risks or considerations.
<span class="callout-end"></span>

## Handle documentation

Suppose you need to add or update documentation for your code.

<span class="steps-start"></span>
  <span class="step-marker" data-step-title="Identify undocumented code"></span>
> find functions without proper JSDoc comments in the auth module 
```

    > add JSDoc comments to the undocumented functions in auth.js 
    ```
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Review and enhance"></span>
> improve the generated documentation with more context and examples 
```

    > check if the documentation follows our project standards 
    ```
  <span class="step-end"></span>
<span class="steps-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * Specify the documentation style you want (JSDoc, docstrings, etc.)
  * Ask for examples in the documentation
  * Request documentation for public APIs, interfaces, and complex logic
<span class="callout-end"></span>

***

## Work with images

Suppose you need to work with images in your codebase, and you want Claude's help analyzing image content.

<span class="steps-start"></span>
  <span class="step-marker" data-step-title="Add an image to the conversation"></span>
You can use any of these methods:

1. Drag and drop an image into the Claude Code window
2. Copy an image and paste it into the CLI with ctrl+v (Do not use cmd+v)
3. Provide an image path to Claude. E.g., "Analyze this image: /path/to/your/image.png"
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Ask Claude to analyze the image"></span>
> What does this image show?
```
    > Describe the UI elements in this screenshot
    ```
> Are there any problematic elements in this diagram?
```

    > Here's a screenshot of the error. What's causing it?
    ```
> This is our current database schema. How should we modify it for the new feature?
```

    > Generate CSS to match this design mockup
    ```
> What HTML structure would recreate this component?
```

Tips:

  • Use images when text descriptions would be unclear or cumbersome
  • Include screenshots of errors, UI designs, or diagrams for better context
  • You can work with multiple images in a conversation
  • Image analysis works with diagrams, screenshots, mockups, and more
  • When Claude references images (for example, [Image #1]), Cmd+Click (Mac) or Ctrl+Click (Windows/Linux) the link to open the image in your default viewer

Reference files and directories#

Use @ to quickly include files or directories without waiting for Claude to read them.

    > Explain the logic in @src/utils/auth.js
    ```

This includes the full content of the file in the conversation.
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Reference a directory"></span>
> What's the structure of @src/components?
```

This provides a directory listing with file information.

    > Show me the data from @github:repos/owner/repo/issues
    ```

This fetches data from connected MCP servers using the format @server:resource. See [MCP resources](/en/mcp#use-mcp-resources) for details.
  <span class="step-end"></span>
<span class="steps-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * File paths can be relative or absolute
  * @ file references add `CLAUDE.md` in the file's directory and parent directories to context
  * Directory references show file listings, not contents
  * You can reference multiple files in a single message (for example, "@file1.js and @file2.js")
<span class="callout-end"></span>

***

## Use extended thinking (thinking mode)

[Extended thinking](https://platform.claude.com/docs/en/build-with-claude/extended-thinking) is enabled by default, giving Claude space to reason through complex problems step-by-step before responding. This reasoning is visible in verbose mode, which you can toggle on with `Ctrl+O`.

Additionally, Opus 4.6 introduces adaptive reasoning: instead of a fixed thinking token budget, the model dynamically allocates thinking based on your [effort level](/en/model-config#adjust-effort-level) setting. Extended thinking and adaptive reasoning work together to give you control over how deeply Claude reasons before responding.

Extended thinking is particularly valuable for complex architectural decisions, challenging bugs, multi-step implementation planning, and evaluating tradeoffs between different approaches.

<span class="callout-start" data-callout-type="note"></span>
  Phrases like "think", "think hard", "ultrathink", and "think more" are interpreted as regular prompt instructions and don't allocate thinking tokens.
<span class="callout-end"></span>

### Configure thinking mode

Thinking is enabled by default, but you can adjust or disable it.

| Scope                  | How to configure                                                                           | Details                                                                                                                                               |
| ---------------------- | ------------------------------------------------------------------------------------------ | ----------------------------------------------------------------------------------------------------------------------------------------------------- |
| **Effort level**       | Adjust in `/model` or set [`CLAUDE_CODE_EFFORT_LEVEL`](/en/settings#environment-variables) | Control thinking depth for Opus 4.6: low, medium, high (default). See [Adjust effort level](/en/model-config#adjust-effort-level)                     |
| **Toggle shortcut**    | Press `Option+T` (macOS) or `Alt+T` (Windows/Linux)                                        | Toggle thinking on/off for the current session (all models). May require [terminal configuration](/en/terminal-config) to enable Option key shortcuts |
| **Global default**     | Use `/config` to toggle thinking mode                                                      | Sets your default across all projects (all models).<br />Saved as `alwaysThinkingEnabled` in `~/.claude/settings.json`                                |
| **Limit token budget** | Set [`MAX_THINKING_TOKENS`](/en/settings#environment-variables) environment variable       | Limit the thinking budget to a specific number of tokens (ignored on Opus 4.6 unless set to 0). Example: `export MAX_THINKING_TOKENS=10000`           |

To view Claude's thinking process, press `Ctrl+O` to toggle verbose mode and see the internal reasoning displayed as gray italic text.

### How extended thinking works

Extended thinking controls how much internal reasoning Claude performs before responding. More thinking provides more space to explore solutions, analyze edge cases, and self-correct mistakes.

**With Opus 4.6**, thinking uses adaptive reasoning: the model dynamically allocates thinking tokens based on the [effort level](/en/model-config#adjust-effort-level) you select (low, medium, high). This is the recommended way to tune the tradeoff between speed and reasoning depth.

**With other models**, thinking uses a fixed budget of up to 31,999 tokens from your output budget. You can limit this with the [`MAX_THINKING_TOKENS`](/en/settings#environment-variables) environment variable, or disable thinking entirely via `/config` or the `Option+T`/`Alt+T` toggle.

`MAX_THINKING_TOKENS` is ignored on Opus 4.6 and Sonnet 4.6, since adaptive reasoning controls thinking depth instead. The one exception: setting `MAX_THINKING_TOKENS=0` still disables thinking entirely on any model. To disable adaptive thinking and revert to the fixed thinking budget, set `CLAUDE_CODE_DISABLE_ADAPTIVE_THINKING=1`. See [environment variables](/en/settings#environment-variables).

<span class="callout-start" data-callout-type="warning"></span>
  You're charged for all thinking tokens used, even though Claude 4 models show summarized thinking
<span class="callout-end"></span>

***

## Resume previous conversations

When starting Claude Code, you can resume a previous session:

* `claude --continue` continues the most recent conversation in the current directory
* `claude --resume` opens a conversation picker or resumes by name
* `claude --from-pr 123` resumes sessions linked to a specific pull request

From inside an active session, use `/resume` to switch to a different conversation.

Sessions are stored per project directory. The `/resume` picker shows sessions from the same git repository, including worktrees.

### Name your sessions

Give sessions descriptive names to find them later. This is a best practice when working on multiple tasks or features.

<span class="steps-start"></span>
  <span class="step-marker" data-step-title="Name the current session"></span>
Use `/rename` during a session to give it a memorable name:
> /rename auth-refactor
```

You can also rename any session from the picker: run /resume, navigate to a session, and press R.

From the command line:

    claude --resume auth-refactor
    ```

Or from inside an active session:
> /resume auth-refactor
```

Use the session picker#

The /resume command (or claude --resume without arguments) opens an interactive session picker with these features:

Keyboard shortcuts in the picker:

ShortcutAction
/ Navigate between sessions
/ Expand or collapse grouped sessions
EnterSelect and resume the highlighted session
PPreview the session content
RRename the highlighted session
/Search to filter sessions
AToggle between current directory and all projects
BFilter to sessions from your current git branch
EscExit the picker or search mode

Session organization:

The picker displays sessions with helpful metadata:

  • Session name or initial prompt
  • Time elapsed since last activity
  • Message count
  • Git branch (if applicable)

Forked sessions (created with /rewind or --fork-session) are grouped together under their root session, making it easier to find related conversations.

Tips:

  • Name sessions early: Use /rename when starting work on a distinct task—it’s much easier to find “payment-integration” than “explain this function” later
  • Use --continue for quick access to your most recent conversation in the current directory
  • Use --resume session-name when you know which session you need
  • Use --resume (without a name) when you need to browse and select
  • For scripts, use claude --continue --print "prompt" to resume in non-interactive mode
  • Press P in the picker to preview a session before resuming it
  • The resumed conversation starts with the same model and configuration as the original

How it works:

  1. Conversation Storage: All conversations are automatically saved locally with their full message history
  2. Message Deserialization: When resuming, the entire message history is restored to maintain context
  3. Tool State: Tool usage and results from the previous conversation are preserved
  4. Context Restoration: The conversation resumes with all previous context intact

Run parallel Claude Code sessions with Git worktrees#

When working on multiple tasks at once, you need each Claude session to have its own copy of the codebase so changes don’t collide. Git worktrees solve this by creating separate working directories that each have their own files and branch, while sharing the same repository history and remote connections. This means you can have Claude working on a feature in one worktree while fixing a bug in another, without either session interfering with the other.

Use the --worktree (-w) flag to create an isolated worktree and start Claude in it. The value you pass becomes the worktree directory name and branch name:

# Start Claude in a worktree named "feature-auth"
# Creates .claude/worktrees/feature-auth/ with a new branch
claude --worktree feature-auth

# Start another session in a separate worktree
claude --worktree bugfix-123

If you omit the name, Claude generates a random one automatically:

# Auto-generates a name like "bright-running-fox"
claude --worktree

Worktrees are created at <repo>/.claude/worktrees/<name> and branch from the default remote branch. The worktree branch is named worktree-<name>.

You can also ask Claude to “work in a worktree” or “start a worktree” during a session, and it will create one automatically.

Subagent worktrees#

Subagents can also use worktree isolation to work in parallel without conflicts. Ask Claude to “use worktrees for your agents” or configure it in a custom subagent by adding isolation: worktree to the agent’s frontmatter. Each subagent gets its own worktree that is automatically cleaned up when the subagent finishes without changes.

Worktree cleanup#

When you exit a worktree session, Claude handles cleanup based on whether you made changes:

  • No changes: the worktree and its branch are removed automatically
  • Changes or commits exist: Claude prompts you to keep or remove the worktree. Keeping preserves the directory and branch so you can return later. Removing deletes the worktree directory and its branch, discarding all uncommitted changes and commits

To clean up worktrees outside of a Claude session, use manual worktree management.

Add .claude/worktrees/ to your .gitignore to prevent worktree contents from appearing as untracked files in your main repository.

Manage worktrees manually#

For more control over worktree location and branch configuration, create worktrees with Git directly. This is useful when you need to check out a specific existing branch or place the worktree outside the repository.

# Create a worktree with a new branch
git worktree add ../project-feature-a -b feature-a

# Create a worktree with an existing branch
git worktree add ../project-bugfix bugfix-123

# Start Claude in the worktree
cd ../project-feature-a && claude

# Clean up when done
git worktree list
git worktree remove ../project-feature-a

Learn more in the official Git worktree documentation.

Remember to initialize your development environment in each new worktree according to your project’s setup. Depending on your stack, this might include running dependency installation (npm install, yarn), setting up virtual environments, or following your project’s standard setup process.

Non-git version control#

Worktree isolation works with git by default. For other version control systems like SVN, Perforce, or Mercurial, configure WorktreeCreate and WorktreeRemove hooks to provide custom worktree creation and cleanup logic. When configured, these hooks replace the default git behavior when you use --worktree.

For automated coordination of parallel sessions with shared tasks and messaging, see agent teams.


Get notified when Claude needs your attention#

When you kick off a long-running task and switch to another window, you can set up desktop notifications so you know when Claude finishes or needs your input. This uses the Notification hook event, which fires whenever Claude is waiting for permission, idle and ready for a new prompt, or completing authentication.

Type /hooks and select Notification from the list of events.

Select + Match all (no filter) to fire on all notification types. To notify only for specific events, select + Add new matcher… and enter one of these values:

MatcherFires when
permission_promptClaude needs you to approve a tool use
idle_promptClaude is done and waiting for your next prompt
auth_successAuthentication completes
elicitation_dialogClaude is asking you a question

Select + Add new hook… and enter the command for your OS:

Uses osascript to trigger a native macOS notification through AppleScript:

```
    osascript -e 'display notification "Claude Code needs your attention" with title "Claude Code"'
    ```

Uses notify-send, which is pre-installed on most Linux desktops with a notification daemon:

```
    notify-send 'Claude Code' 'Claude Code needs your attention'
    ```

Uses PowerShell to show a native message box through .NET’s Windows Forms:

```
    powershell.exe -Command "[System.Reflection.Assembly]::LoadWithPartialName('System.Windows.Forms'); [System.Windows.Forms.MessageBox]::Show('Claude Code needs your attention', 'Claude Code')"
    ```

Select User settings to apply the notification across all your projects.

For the full walkthrough with JSON configuration examples, see Automate workflows with hooks. For the complete event schema and notification types, see the Notification reference.


Use Claude as a unix-style utility#

Add Claude to your verification process#

Suppose you want to use Claude Code as a linter or code reviewer.

Add Claude to your build script:

// package.json
{
    ...
    "scripts": {
        ...
        "lint:claude": "claude -p 'you are a linter. please look at the changes vs. main and report any issues related to typos. report the filename and line number on one line, and a description of the issue on the second line. do not return any other text.'"
    }
}

Tips:

  • Use Claude for automated code review in your CI/CD pipeline
  • Customize the prompt to check for specific issues relevant to your project
  • Consider creating multiple scripts for different types of verification

Pipe in, pipe out#

Suppose you want to pipe data into Claude, and get back data in a structured format.

Pipe data through Claude:

cat build-error.txt | claude -p 'concisely explain the root cause of this build error' > output.txt

Tips:

  • Use pipes to integrate Claude into existing shell scripts
  • Combine with other Unix tools for powerful workflows
  • Consider using –output-format for structured output

Control output format#

Suppose you need Claude’s output in a specific format, especially when integrating Claude Code into scripts or other tools.

    cat data.txt | claude -p 'summarize this data' --output-format text > summary.txt
    ```

This outputs just Claude's plain text response (default behavior).
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Use JSON format"></span>
```bash
    cat code.py | claude -p 'analyze this code for bugs' --output-format json > analysis.json
    ```

This outputs a JSON array of messages with metadata including cost and duration.
  <span class="step-end"></span>

  <span class="step-marker" data-step-title="Use streaming JSON format"></span>
```bash
    cat log.txt | claude -p 'parse this log file for errors' --output-format stream-json
    ```

This outputs a series of JSON objects in real-time as Claude processes the request. Each message is a valid JSON object, but the entire output is not valid JSON if concatenated.
  <span class="step-end"></span>
<span class="steps-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * Use `--output-format text` for simple integrations where you just need Claude's response
  * Use `--output-format json` when you need the full conversation log
  * Use `--output-format stream-json` for real-time output of each conversation turn
<span class="callout-end"></span>

***

## Ask Claude about its capabilities

Claude has built-in access to its documentation and can answer questions about its own features and limitations.

### Example questions

can Claude Code create pull requests?

how does Claude Code handle permissions?

what skills are available?

how do I use MCP with Claude Code?

how do I configure Claude Code for Amazon Bedrock?

what are the limitations of Claude Code?


<span class="callout-start" data-callout-type="note"></span>
  Claude provides documentation-based answers to these questions. For executable examples and hands-on demonstrations, refer to the specific workflow sections above.
<span class="callout-end"></span>

<span class="callout-start" data-callout-type="tip"></span>
  Tips:

  * Claude always has access to the latest Claude Code documentation, regardless of the version you're using
  * Ask specific questions to get detailed answers
  * Claude can explain complex features like MCP integration, enterprise configurations, and advanced workflows
<span class="callout-end"></span>

***

## Next steps

<span class="card-group-start" data-cols="2"></span>
  <span class="card-start" data-card-title="Best practices" data-card-icon="lightbulb" data-card-href="/en/best-practices"></span>
Patterns for getting the most out of Claude Code
  <span class="card-end"></span>

  <span class="card-start" data-card-title="How Claude Code works" data-card-icon="gear" data-card-href="/en/how-claude-code-works"></span>
Understand the agentic loop and context management
  <span class="card-end"></span>

  <span class="card-start" data-card-title="Extend Claude Code" data-card-icon="puzzle-piece" data-card-href="/en/features-overview"></span>
Add skills, hooks, MCP, subagents, and plugins
  <span class="card-end"></span>

  <span class="card-start" data-card-title="Reference implementation" data-card-icon="code" data-card-href="https://github.com/anthropics/claude-code/tree/main/.devcontainer"></span>
Clone our development container reference implementation
  <span class="card-end"></span>
<span class="card-group-end"></span>
Link last verified June 7, 2026. View original ↗
Source: Claude Code Docs

Appears in Learning Paths

Link last verified: 2026-02-26