2021-05-27 12:34:41 +00:00
## branch-names
2023-02-16 05:03:34 +00:00
[](https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idruns -on)
[](https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idruns -on)
[](https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#jobsjob_idruns -on)
2023-05-27 15:17:04 -06:00
[](https://github.com/search?o=desc\&q=tj-actions+branch-names+language%3AYAML\&s=\&type=Code)
2021-08-23 01:16:54 +00:00
2024-01-21 17:17:26 +00:00
[](https://app.codacy.com/gh/tj-actions/branch-names/dashboard?utm_source=gh\&utm_medium=referral\&utm_content=\&utm_campaign=Badge_grade)
2022-12-18 20:42:17 +00:00
[](https://github.com/tj-actions/branch-names/actions?query=workflow%3ACI)
[](https://github.com/tj-actions/branch-names/actions/workflows/sync-release-version.yml)
2021-09-20 13:30:30 -04:00
2021-08-23 01:13:52 +00:00
<!-- ALL - CONTRIBUTORS - BADGE:START - Do not remove or modify this section -->
2024-03-02 01:37:11 +00:00
2024-03-01 18:36:45 -07:00
[](#contributors -)
2024-03-02 01:37:11 +00:00
2021-08-23 01:13:52 +00:00
<!-- ALL - CONTRIBUTORS - BADGE:END -->
2020-12-11 08:15:40 -05:00
2022-12-28 16:18:56 -07:00
Get a branch or tag name without the `/ref/*` prefix.
2020-12-11 08:15:40 -05:00
2023-11-03 19:46:07 -06:00
## Table of Contents
2023-11-03 19:47:16 -06:00
* [Features ](#features )
* [Usage ](#usage )
* [Inputs ](#inputs )
2023-12-02 11:47:00 +00:00
* [Outputs ](#outputs )
2023-11-03 19:47:16 -06:00
* [Events ](#events )
* [`push*` ](#push )
* [`pull_request*` ](#pull_request )
* [`tag*` ](#tag )
2023-11-03 19:50:47 -06:00
* [Other supported events ](#other-supported-events )
2024-07-04 04:16:08 -06:00
* [Possible usage with actions/checkout ](#possible-usage-with-actionscheckout )
2023-11-03 19:47:16 -06:00
* [Credits ](#credits )
* [Report Bugs ](#report-bugs )
* [Contributors ✨ ](#contributors- )
2021-08-26 08:34:59 -04:00
## Features
2021-08-26 12:39:46 +00:00
* Retrieve the current branch name without any prefix. (e.g. `'refs/heads/main'` -> `'main'` )
2022-03-16 04:16:27 -04:00
* Retrieve the current tag with an option to strip the prefix (e.g. `v0.0.1` -> `v` -> `0.0.1` )
2021-08-26 12:39:46 +00:00
* Detect actions triggered by non default branches
* Detect actions triggered by the default branch
2021-11-02 19:33:48 +00:00
* Supports all valid [git branch names ](https://wincent.com/wiki/Legal_Git_branch_names )
2021-08-26 08:34:59 -04:00
2021-05-27 12:34:41 +00:00
## Usage
2021-02-07 20:19:06 -05:00
2021-04-04 15:42:46 -04:00
```yaml
...
2022-11-12 15:49:17 -07:00
2021-04-04 15:42:46 -04:00
steps:
2023-12-02 04:45:28 -07:00
- name: Get branch names.
id: branch-names
2023-12-07 04:26:34 +00:00
uses: tj-actions/branch-names@v8
2021-06-07 11:25:35 -04:00
2021-07-01 08:10:48 -04:00
- name: Running on the default branch.
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_default == 'true'
2021-06-01 10:01:16 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "Running on default: ${{ steps.branch-names.outputs.current_branch }}"
2023-05-01 03:07:51 -06:00
# Outputs: "Running on default: main"
2021-07-01 08:10:48 -04:00
- name: Running on a pull request branch.
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_default == 'false'
2021-06-01 10:01:16 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "Running on pr: ${{ steps.branch-names.outputs.current_branch }}"
2023-05-01 03:07:51 -06:00
# Outputs: "Running on pr: feature/test"
- name: Running on a pull request branch.
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_default == 'false'
2023-05-01 03:07:51 -06:00
run: |
2023-12-02 04:45:28 -07:00
echo "Base branch: ${{ steps.branch-names.outputs.base_ref_branch }}"
2023-05-01 03:07:51 -06:00
# Outputs: "Base branch: main"
2023-12-02 04:45:28 -07:00
- name: Running on any event.
2023-05-01 03:07:51 -06:00
run: |
2023-12-02 04:45:28 -07:00
echo "Default branch: ${{ steps.branch-names.outputs.default_branch }}"
2023-05-01 03:07:51 -06:00
# Outputs: "Default branch: main"
2021-04-04 15:42:46 -04:00
```
2021-11-24 14:03:32 -05:00
If you feel generous and want to show some extra appreciation:
Support this project with a :star:
[![Buy me a coffee][buymeacoffee-shield]][buymeacoffee]
[buymeacoffee]: https://www.buymeacoffee.com/jackton1
[buymeacoffee-shield]: https://www.buymeacoffee.com/assets/img/custom_images/orange_img.png
2021-07-05 07:52:36 -04:00
## Inputs
2022-03-22 21:21:35 +00:00
<!-- AUTO - DOC - INPUT:START - Do not remove or modify this section -->
2023-12-02 11:30:41 +00:00
```yaml
2023-12-07 04:26:34 +00:00
- uses: tj-actions/branch-names@v8
2023-12-02 11:30:41 +00:00
id: branch-names
with:
2024-05-04 18:05:41 +00:00
# The prefix that should be
# stripped from the tag e.g
# `v` -> with a tag
# `v0.0.1` -> returns `0.0.1`
2023-12-02 11:30:41 +00:00
# Type: string
strip_tag_prefix: ''
```
2022-03-22 21:21:35 +00:00
<!-- AUTO - DOC - INPUT:END -->
2023-12-02 04:46:38 -07:00
## Outputs
2023-12-02 11:47:00 +00:00
<!-- AUTO - DOC - OUTPUT:START - Do not remove or modify this section -->
| OUTPUT | TYPE | DESCRIPTION |
|---------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------|
| < a name = "output_base_ref_branch" ></ a > [base\_ref\_branch ](#output_base_ref_branch ) | string | The target branch of a < br > pull request or tag e.g < br > `main` |
| < a name = "output_current_branch" ></ a > [current\_branch ](#output_current_branch ) | string | The current branch name regardless < br > of event\_type e.g `main` , `feature/test` |
| < a name = "output_default_branch" ></ a > [default\_branch ](#output_default_branch ) | string | The default branch name e.g < br > `main` OR `master` |
| < a name = "output_head_ref_branch" ></ a > [head\_ref\_branch ](#output_head_ref_branch ) | string | The source branch of a < br > pull request e.g `feature/test` |
| < a name = "output_is_default" ></ a > [is\_default ](#output_is_default ) | string | Returns `"true"` if the current < br > branch is the default else < br > `"false"` . |
| < a name = "output_is_tag" ></ a > [is\_tag ](#output_is_tag ) | string | Returns `"true"` if the current < br > branch is a tag else < br > `"false"` . |
| < a name = "output_ref_branch" ></ a > [ref\_branch ](#output_ref_branch ) | string | The branch that triggered the < br > workflow run. e.g `1/merge` , `main` |
| < a name = "output_tag" ></ a > [tag ](#output_tag ) | string | The tag that triggered the < br > workflow run. e.g `v0.0.1` , `0.0.1` |
<!-- AUTO - DOC - OUTPUT:END -->
2021-07-05 17:24:11 -04:00
## Events
2023-08-29 11:51:42 -06:00
### `push*`
2021-04-04 15:42:46 -04:00
2020-12-11 08:15:40 -05:00
```yaml
2021-07-05 17:24:11 -04:00
on:
push:
branches:
- main
2020-12-11 08:15:40 -05:00
...
steps:
2020-12-11 10:39:03 -05:00
- name: Get branch names
2023-12-02 04:45:28 -07:00
id: branch-names
2023-12-07 04:26:34 +00:00
uses: tj-actions/branch-names@v8
2021-05-27 08:17:23 -04:00
2023-12-02 04:45:28 -07:00
- name: Current branch names
2021-07-05 17:24:11 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.current_branch }}"
2021-07-05 17:24:11 -04:00
# Outputs: "main" the branch that triggered the push event.
2021-02-14 08:19:07 -05:00
- name: Running on the default branch.
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_default == 'true'
2021-02-14 08:19:07 -05:00
run: |
2023-12-02 04:45:28 -07:00
echo "Running on default: ${{ steps.branch-names.outputs.current_branch }}"
2021-02-15 13:19:33 -05:00
# Outputs: "Running on default: main".
2021-02-14 08:19:07 -05:00
2021-07-05 17:24:11 -04:00
- name: Running on the default branch (i.e non tag based branch).
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_tag == 'false' & & steps.branch-names.outputs.is_default == 'true'
2021-05-27 08:17:23 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "Running on branch: ${{ steps.branch-names.outputs.current_branch }}"
2021-05-27 08:17:23 -04:00
# Outputs: "Running on branch: main".
2021-07-06 06:28:07 -04:00
- name: Get Ref brach name
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.ref_branch }}"
2021-07-06 06:28:07 -04:00
# Outputs: "main"
2022-03-22 17:47:12 -04:00
- name: Default branch name
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.default_branch }}"
2022-03-22 17:47:12 -04:00
# Outputs: "main" the default branch.
2021-07-05 17:24:11 -04:00
```
2023-08-29 11:51:42 -06:00
### `pull_request*`
2021-07-05 17:24:11 -04:00
```yaml
on:
pull_request:
branches:
- main
...
steps:
- name: Get branch names
2023-12-02 04:45:28 -07:00
id: branch-names
2023-12-07 04:26:34 +00:00
uses: tj-actions/branch-names@v8
2021-02-07 19:45:09 -05:00
2023-12-02 04:45:28 -07:00
- name: Current branch names
2021-02-07 19:45:09 -05:00
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.current_branch }}"
2021-02-08 17:12:17 -05:00
# Outputs: "feature/test" current PR branch.
2021-07-05 17:24:11 -04:00
- name: Running on a non tag based branch and a PR branch.
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_default == 'false'
2021-02-07 19:45:09 -05:00
run: |
2023-12-02 04:45:28 -07:00
echo "Running on branch: ${{ steps.branch-names.outputs.current_branch }}"
2021-07-05 17:24:11 -04:00
# Outputs: "Running on branch: feature/test".
2021-02-07 19:45:09 -05:00
2021-07-05 17:24:11 -04:00
- name: Running on a pull request (i.e non tag based branch).
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_tag == 'false' & & steps.branch-names.outputs.is_default == 'false'
2020-12-11 08:52:52 -05:00
run: |
2023-12-02 04:45:28 -07:00
echo "Running on branch: ${{ steps.branch-names.outputs.current_branch }}"
2021-07-05 17:24:11 -04:00
# Outputs: "Running on branch: feature/test".
2021-07-06 06:28:07 -04:00
2022-03-22 17:47:12 -04:00
- name: Get Ref branch name
2021-07-06 06:28:07 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.ref_branch }}"
2021-07-06 06:28:07 -04:00
# Outputs: "1/merge"
2023-12-02 04:45:28 -07:00
- name: Get Head Ref branch names (i.e The current pull request branch)
2021-07-06 06:28:07 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.head_ref_branch }}"
2021-07-06 06:28:07 -04:00
# Outputs: "feature/test" current PR branch.
2023-12-02 04:45:28 -07:00
- name: Get Base Ref branch names (i.e The target of a pull request.)
2021-07-06 06:28:07 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.base_ref_branch }}"
2021-07-06 06:28:07 -04:00
# Outputs: "main".
2022-03-22 17:47:12 -04:00
2023-12-02 04:45:28 -07:00
- name: Default branch names
2022-03-22 17:47:12 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.default_branch }}"
2022-03-22 17:47:12 -04:00
# Outputs: "main" the default branch.
2021-07-05 17:24:11 -04:00
```
2020-12-11 08:52:52 -05:00
2023-08-29 11:51:42 -06:00
### `tag*`
2021-07-05 17:24:11 -04:00
```yaml
on:
push:
tags:
- '*'
2020-12-11 08:52:52 -05:00
2021-07-05 17:24:11 -04:00
...
steps:
- name: Get branch names
2023-12-02 04:45:28 -07:00
id: branch-names
2023-12-07 04:26:34 +00:00
uses: tj-actions/branch-names@v8
2023-08-29 11:49:26 -06:00
with:
strip_tag_prefix: v # Optionally strip the leading `v` from the tag.
2021-07-05 17:24:11 -04:00
- name: Running on a tag branch.
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_tag == 'true'
2020-12-11 08:52:52 -05:00
run: |
2023-12-02 04:45:28 -07:00
echo "Running on: ${{ steps.branch-names.outputs.tag }}"
2023-11-01 01:00:38 -06:00
# Outputs: "Running on: 0.0.1".
2021-04-24 06:41:16 -04:00
- name: Get the current tag
2023-12-02 04:45:28 -07:00
if: steps.branch-names.outputs.is_tag == 'true' # Replaces: startsWith(github.ref, 'refs/tags/')
2021-04-24 06:41:16 -04:00
run: |
2023-12-02 04:45:28 -07:00
echo "${{ steps.branch-names.outputs.tag }}"
2023-11-01 01:00:38 -06:00
# Outputs: "0.0.1"
2020-12-11 08:15:40 -05:00
```
2023-11-03 19:49:51 -06:00
### Other supported events
2023-12-18 13:57:31 -07:00
See [.github/workflows/test.yml ](https://github.com/tj-actions/branch-names/blob/main/.github/workflows/test.yml ) for more examples.
2023-11-03 19:49:51 -06:00
2024-07-04 04:15:10 -06:00
### Possible usage with [actions/checkout](https://github.com/actions/checkout)
2020-12-11 12:42:26 -05:00
```yaml
2020-12-11 16:18:42 -05:00
on:
pull_request:
branches:
- develop
jobs:
test:
runs-on: ubuntu-latest
steps:
2020-12-11 12:42:26 -05:00
- name: Get branch names.
id: branch-names
2023-12-07 04:26:34 +00:00
uses: tj-actions/branch-names@v8
2024-03-02 02:41:24 +01:00
- uses: actions/checkout@v4
2020-12-11 12:42:26 -05:00
with:
2021-06-23 17:09:32 -04:00
ref: ${{ steps.branch-names.outputs.head_ref_branch }}
2020-12-11 12:42:26 -05:00
```
2021-06-05 20:54:10 +00:00
* Free software: [MIT license ](LICENSE )
2021-06-05 16:53:34 -04:00
2021-05-27 12:34:41 +00:00
## Credits
2020-12-11 08:15:40 -05:00
This package was created with [Cookiecutter ](https://github.com/cookiecutter/cookiecutter ).
2021-05-27 12:34:41 +00:00
## Report Bugs
2020-12-11 08:15:40 -05:00
2020-12-11 10:26:26 -05:00
Report bugs at https://github.com/tj-actions/branch-names/issues.
2020-12-11 08:15:40 -05:00
If you are reporting a bug, please include:
2021-05-27 12:34:41 +00:00
* Your operating system name and version.
* Any details about your workflow that might be helpful in troubleshooting.
* Detailed steps to reproduce the bug.
2021-08-23 01:13:52 +00:00
## Contributors ✨
Thanks goes to these wonderful people ([emoji key ](https://allcontributors.org/docs/en/emoji-key )):
<!-- ALL - CONTRIBUTORS - LIST:START - Do not remove or modify this section -->
2024-03-02 01:37:11 +00:00
2021-08-23 01:13:52 +00:00
<!-- prettier - ignore - start -->
2024-03-02 01:37:11 +00:00
2021-08-23 01:13:52 +00:00
<!-- markdownlint - disable -->
2024-03-02 01:37:11 +00:00
2021-08-23 01:13:52 +00:00
< table >
2023-08-23 10:49:25 -06:00
< tbody >
< tr >
< td align = "center" valign = "top" width = "14.28%" > < a href = "https://github.com/loarca" > < img src = "https://avatars.githubusercontent.com/u/22898638?v=4?s=100" width = "100px;" alt = "Alejandro Loarca" / > < br / > < sub > < b > Alejandro Loarca< / b > < / sub > < / a > < br / > < a href = "https://github.com/tj-actions/branch-names/commits?author=loarca" title = "Code" > 💻< / a > < / td >
< td align = "center" valign = "top" width = "14.28%" > < a href = "https://ianwoodard.me" > < img src = "https://avatars.githubusercontent.com/u/17186604?v=4?s=100" width = "100px;" alt = "Ian Woodard" / > < br / > < sub > < b > Ian Woodard< / b > < / sub > < / a > < br / > < a href = "https://github.com/tj-actions/branch-names/commits?author=IanWoodard" title = "Documentation" > 📖< / a > < / td >
2024-03-01 18:36:45 -07:00
< td align = "center" valign = "top" width = "14.28%" > < a href = "https://home.boidol.dev/" > < img src = "https://avatars.githubusercontent.com/u/652404?v=4?s=100" width = "100px;" alt = "Raphael Boidol" / > < br / > < sub > < b > Raphael Boidol< / b > < / sub > < / a > < br / > < a href = "https://github.com/tj-actions/branch-names/commits?author=boidolr" title = "Documentation" > 📖< / a > < / td >
2023-08-23 10:49:25 -06:00
< / tr >
< / tbody >
2021-08-23 01:13:52 +00:00
< / table >
<!-- markdownlint - restore -->
2024-03-02 01:37:11 +00:00
2021-08-23 01:13:52 +00:00
<!-- prettier - ignore - end -->
<!-- ALL - CONTRIBUTORS - LIST:END -->
2021-08-22 21:16:18 -04:00
This project follows the [all-contributors ](https://github.com/all-contributors/all-contributors ) specification. Contributions of any kind welcome!