> For the complete documentation index, see [llms.txt](https://docs.sonarsource.com/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://docs.sonarsource.com/sonarqube-server/2025.6/analyzing-source-code/branch-analysis/introduction.md).

# Introduction

Branch analysis allows you to trigger an analysis on a push to any specified branch (not just the main branch) without involving pull requests. This capability can be useful in the following situations:

* When your project has branches other than the main branch that you want to analyze. One use case is having branches for older versions of your software that you still periodically update with critical fixes. Another is having separate branches for development and production in your project.
* When you use branches (for example, "feature" branches) to introduce changes to your main branch but do not use them with a pull request mechanism in a supported CI.
* When you change the main branch in your CI service and SonarQube isn't recognizing the new branch as the main branch, you can trigger an analysis of the new main branch so it can be specified as the main branch in SonarQube.

You can limit the branch analysis to relevant branches only.

## Focus on new code

The quality gate of your project applies to your branch (you cannot define a quality gate at the branch level). It lets you know if your branch is ready to be merged.

[New code](/sonarqube-server/2025.6/user-guide/about-new-code.md) can be defined at the branch level.

## Incremental branch analysis <a href="#incremental-analysis" id="incremental-analysis"></a>

Some analyzers use the [analysis cache mechanism](/sonarqube-server/2025.6/analyzing-source-code/incremental-analysis.md) to shorten the branch analysis. This way, they analyze only the code sections that are affected by the changes in the branch compared to the previous analysis.

## Issue synchronization <a href="#issue-synchronization" id="issue-synchronization"></a>

SonarQube Server synchronizes issue attributes (status, assignee, changelog, comments) between branches when a branch is created or (under particular conditions) merged. For more information, see the corresponding section on the [Issue management solution](/sonarqube-server/2025.6/user-guide/issues/solution-overview.md) page.

## Related pages <a href="#related-pages" id="related-pages"></a>

* [Setting up the branch analysis](/sonarqube-server/2025.6/analyzing-source-code/branch-analysis/setting-up-the-branch-analysis.md)
* [Maintaining project branches](/sonarqube-server/2025.6/project-administration/maintaining-project/maintaining-the-branches-of-your-project.md).
* [About the incremental analysis](/sonarqube-server/2025.6/analyzing-source-code/incremental-analysis/introduction.md)


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter, and the optional `goal` query parameter:

```
GET https://docs.sonarsource.com/sonarqube-server/2025.6/analyzing-source-code/branch-analysis/introduction.md?ask=<question>&goal=<endgoal>
```

`ask` is the immediate question: it should be specific, self-contained, and written in natural language.
`goal` is optional and describes the broader end goal you are ultimately trying to accomplish on behalf of the user. GitBook uses it to tailor the answer towards what is most useful for that goal.

The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
