Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/erbridge/github-branch-renamer
Rename the 'master' branch for an entire account at once
https://github.com/erbridge/github-branch-renamer
gbr renaming-branches
Last synced: 3 months ago
JSON representation
Rename the 'master' branch for an entire account at once
- Host: GitHub
- URL: https://github.com/erbridge/github-branch-renamer
- Owner: erbridge
- License: mit
- Created: 2020-06-14T21:17:40.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2022-05-26T21:40:39.000Z (over 2 years ago)
- Last Synced: 2024-10-04T17:33:20.570Z (3 months ago)
- Topics: gbr, renaming-branches
- Language: Shell
- Homepage:
- Size: 64.5 KB
- Stars: 9
- Watchers: 4
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# GitHub Branch Renamer
A tool to rename the `master` branch for an entire account at once.
## Installation
### macOS
Install with Homebrew.
```sh
brew install erbridge/tap/github-branch-renamer
```### Everything else
You're on your own, I'm afraid. Refer to the [`Brewfile`](Brewfile) for clues
about required dependencies.## Usage
```
$ gbr
Rename the 'master' branch for an entire account at once.This tool will find all repositories on GitHub belonging to an account that:
- aren't forks
- aren't archived or disabled
- have their default branch set to 'master'It will then rename the master branch to 'main' by default, and set that as the
default branch on GitHub instead of 'master'.By default, the 'master' branch will be left untouched to prevent any accidental
data loss. If you'd like to delete those branches, set the '--delete' flag.You must choose to either do a dry run ('--dry-run') or force the changes
('--force'). You must also specify one of '--org' or '--user' (but not both) to
select the account to collect repositories from.USAGE
gbr [flags]FLAGS
-u, --user string The username to collect repositories in
-o, --org string The organization to collect repositories in
-t, --team string The team within the organization (optional)
-b, --new-branch string The new name for the master branch (defaults to
'main')
-d, --delete Delete the master branch from GitHub
-n, --dry-run Report what will happen, without making any changes
on GitHub
-f, --force Run for real, making changes on GitHub
-l, --list Print a list of all GitHub repositories that would
be changed and exit (implies a dry run)
```## Why?
The conversation about the origin of "master" as a term in technology has come
back around again recently. It's clear that Git's default branch name, `master`,
[originated from a master-slave metaphor](https://mail.gnome.org/archives/desktop-devel-list/2019-May/msg00066.html),
and even if it didn't, it still has that connotation for some people. We should
rename our branches to something else to reduce the harm our language causes.Renaming branches can be a time consuming, manual process, especially if your
repositories are counted in the hundreds. It would be preferable to automate as
much of that as possible. This tool attempts to do that.This tool is limited to existing repositories. Until Git changes its defaults,
new repositories will still be created with a `master` branch. See
[Leigh Brenecki's post](https://leigh.net.au/writing/git-init-main/) for how to
override that default behaviour.