# Branch analysis

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 that 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/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/discovering/code-analysis/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 [Broken mention](broken://pages/UyiiWqk3RHHmLFcoZzLF) page.

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

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


---

# Agent Instructions: 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:

```
GET https://docs.sonarsource.com/sonarqube-server/discovering/code-analysis/branch-analysis.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
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.
