git town hack

git town hack [<branch-name>...] [-p | --prototype] [-d | --detached] [--dry-run] [-v | --verbose]

The hack command (“let’s start hacking”) creates a new feature branch with the given name off the main branch and brings all uncommitted changes over to it.

If your Git workspace is clean (no uncommitted changes), it also syncs the main branch to ensure you develop on top of the current state of the repository. If the workspace is not clean (contains uncommitted changes), git town hack does not perform this sync to let you commit your open changes.

Upstream remote

If the repository contains a remote called upstream, it also syncs the main branch with its upstream counterpart. You can control this behavior with the sync-upstream flag.

Positional arguments

When given a non-existing branch name, git town hack creates a new feature branch with the main branch as its parent.

When given an existing contribution, observed, parked, or prototype branch, git town hack converts that branch to a feature branch.

When given no arguments, git town hack converts the current contribution, observed, parked, or prototype branch into a feature branch.

Options

-p
--prototype

Adding the --prototype aka -p switch creates a prototype branch.

-d
--detached

The --detached aka -d flag does not pull updates from the main or perennial branch. This allows you to build out your branch stack and decide when to pull in changes from other developers.

--dry-run

Use the --dry-run flag to test-drive this command. It prints the Git commands that would be run but doesn’t execute them.

-v
--verbose

The --verbose aka -v flag prints all Git commands run under the hood to determine the repository state.

Configuration

If push-new-branches is set, git town hack creates a remote tracking branch for the new feature branch. This behavior is disabled by default to make git town hack run fast. The first run of git town sync will create the remote tracking branch.

If the configuration setting new-branch-type is set, git town hack creates a branch with the given type.