Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

clear-branches

Package Overview
Dependencies
Maintainers
1
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

clear-branches

easy way to clear your local branches

  • 1.0.1-rc9
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
2
Maintainers
1
Weekly downloads
 
Created
Source

clear-branches

Productive and easy way to clear your local git branches

Getting started

Overview

It's recommended for you who:

  • Usually struggle in clearing your local git branches.
  • Anyone that doesn't have the habit of deleting the branches constantly and gets crazy managing a lot of branches.
  • Prefer using a terminal rather than a Git GUI Client.

Motivation

I implemented this code once ago, as a tiny and ugly script only to help me to be more productive. And I realized that some colleagues were looking for something like this and I've published it to be available to anyone else to use and contribute.

Requirement

Recommended node version equal to or greater than v16

Quick start

You don't need to install it globally, if the idea is to use it sometimes, you can just execute it into your git project, so that you will execute the latest stable version.

$ npx clear-branches

Or install it on your machine:

yarn:

$ yarn global add clear-branches

npm:

$ npm i -g clear-branches

If you're using nvm to manage node versions, pay attention to the node version you're using to create the alias in your bash profile:

alias clear-branches="node ~/.nvm/versions/node/v19.3.0/lib/node_modules/clear-branches"

Creating a dynamic alias that will execute from the current node version forces the user to be in the same version that clear-branches was installed.

alias clear-branches="node $(npm root --global)/clear-branches"

output

Now clear-branches is executable anywhere you want, if you try into your project you will see the list of branches it will delete and a confirmation message:

$ clear-branches
  feat/component
  feat/feature
  fix/functions
? Are you sure you want to delete listed branches above? › (y/N)

Advanced options

Considering a project with these branches:

  feat/component
  feat/feature
  fix/functions
  main
  release

clear-branches --force=<branch>[,<branch>]

It force ignored branches by default to be considered to clear.

By default, clear-branches ignores these branches.

  main
  master
  release
  develop

Using clear-branches --force=<branch>[,<branch>], you will be able not to ignore any of these branches.

I.e.:

$ clear-branches --force=main
  feat/component
  feat/feature
  fix/functions
  main  # <-- now main is in the list to deleted
? Are you sure you want to delete listed branches above? › (y/N)

clear-branches --ignore=<branch>[,<branch>]

It ignores the branches you don't want to delete.

I.e.:

$ clear-branches --ignores=feat/component,feat/feature
  fix/functions
? Are you sure you want to delete listed branches above? › (y/N)

In this example, feat/component and feat/feature won't be deleted.

clear-branches --ignore-pattern=

It ignores all branches that match a regex.

I.e.:

$ clear-branches --ignores=feat\/\\w+
  fix/functions
? Are you sure you want to delete listed branches above? › (y/N)

_As both feat/component and feat/feature match the feat\/\\w+ regex, they won't be deleted.

It's needed to escape if you need to use \, like \\w+

clear-branches -i, --interactive

With this option, you can select the branch you want to delete.

I.e.:

$ clear-branches -i --force=release,main
? Choose the branches you want to delete: ›
Instructions:
    ↑/↓: Highlight option
    ←/→/[space]: Toggle selection
    a: Toggle all
    enter/return: Complete answer
◉   feat/component
◉   feat/feature
◯   fix/functions
◯   release
◯   main

After pressing Enter:

$ clear-branches -i --force=release,main
✔ Choose the branches you want to delete: › feat/component, feat/feature
? Are you sure you want to delete listed branches above? › (y/N)

Contributing

Cloning and running

Testing

Architecture

Issues

To comfortable start contributing to this project, it is encouraged you go for this list of good start issues:

  • Good first issues

More labels

Contributors

FAQs

Package last updated on 15 Jan 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc