hub helps you win at git.
mislav Merge pull request #1996 from github/fix-label-sort
Fix alphabetical sort of `hub issue labels` output
Latest commit 757e68e Jan 3, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.ctags.d Rename `ctags` file for compatibility with universal-ctags Jun 6, 2018
cmd Avoid `copy` when making a subslice May 29, 2018
commands Print usage help on stdout when `--help` was requested Jan 3, 2019
coverage Measure code coverage between tests Jun 7, 2018
etc Clarify documentation about what constitutes a title in `--message` Nov 28, 2018
features Fix alphabetical sort of `hub issue labels` output Jan 3, 2019
fixtures Preserve order of hosts in hub config file Jan 2, 2019
git Support git versions that don't recognize --no-verbose Dec 11, 2018
github Fix alphabetical sort of `hub issue labels` output Jan 3, 2019
md2roff-bin Fix version string appearing in man pages Jan 2, 2019
md2roff Have level-2 headings appear in upper-case in man pages Jan 2, 2019
script build: respect environment LDFLAGS and strip the build path Jan 2, 2019
share Switch to new md2roff process in `make man-pages` Dec 29, 2018
ui ui Printf functions: handle errors by dying Dec 22, 2018
utils 256-color terminal support Dec 28, 2018
vendor Add Blackfriday dependency Dec 29, 2018
version hub 2.7.0 Dec 28, 2018
.agignore Ignore `bundle/` directory when searching Feb 21, 2018
.gitattributes Enforce unix eol in bash script files Sep 2, 2017
.gitignore Switch to new md2roff process in `make man-pages` Dec 29, 2018
.travis.yml Test with Go 1.11 Aug 29, 2018
CODE_OF_CONDUCT.md Improve contact email, part 2 Aug 28, 2017
CONTRIBUTING.md Fix link to README Nov 2, 2018
Gemfile Remove Ruby ronn from build toolchain Dec 29, 2018
Gemfile.lock Remove Ruby ronn from build toolchain Dec 29, 2018
Gopkg.lock Add Blackfriday dependency Dec 29, 2018
Gopkg.toml Add Blackfriday dependency Dec 29, 2018
LICENSE MIT Dec 8, 2009
Makefile Support `trimpath` for Go v1.8/1.9 Jan 2, 2019
README.md Provide correct instructions to build github/hub Nov 2, 2018
Vagrantfile Use Go 1.4.2 Apr 12, 2015
cucumber.yml Detect tmux and run shell completion tests Nov 14, 2013
main.go Enforce go1.8+ via build flags too May 17, 2017
man-template.html Add HTML template for man pages Dec 29, 2018

README.md

git + hub = github

hub is a command line tool that wraps git in order to extend it with extra features and commands that make working with GitHub easier.

$ hub clone rtomayko/tilt

# expands to:
$ git clone git://github.com/rtomayko/tilt.git

hub is best aliased as git, so you can type $ git <command> in the shell and get all the usual hub features. See "Aliasing" below.

See Usage documentation for the list of all commands and their arguments.

Installation

Dependencies:

  • git 1.7.3 or newer

Homebrew

hub can be installed through Homebrew on macOS:

$ brew install hub
$ hub version
git version 1.7.6
hub version 2.2.3

Windows

hub can be installed through Scoop on Windows:

> scoop install hub

Fedora Linux

On Fedora you can install hub through DNF:

$ sudo dnf install hub
$ hub version
git version 2.9.3
hub version 2.2.9

Arch Linux

On Arch Linux you can install hub from official repository:

$ sudo pacman -S hub

Standalone

hub can be easily installed as an executable. Download the latest compiled binaries and put it anywhere in your executable path.

Source

With your GOPATH already set up:

mkdir -p "$GOPATH"/src/github.com/github
git clone \
  --config transfer.fsckobjects=false \
  --config receive.fsckobjects=false \
  --config fetch.fsckobjects=false \
  https://github.com/github/hub.git "$GOPATH"/src/github.com/github/hub
cd "$GOPATH"/src/github.com/github/hub
make install prefix=/usr/local

Prerequisites for compilation are:

  • make
  • Go 1.8+
  • Ruby 1.9+ with Bundler - for generating man pages

Aliasing

Using hub feels best when it's aliased as git. This is not dangerous; your normal git commands will all work. hub merely adds some sugar.

hub alias displays instructions for the current shell. With the -s flag, it outputs a script suitable for eval.

You should place this command in your .bash_profile or other startup script:

eval "$(hub alias -s)"

PowerShell

If you're using PowerShell, you can set an alias for hub by placing the following in your PowerShell profile (usually ~/Documents/WindowsPowerShell/Microsoft.PowerShell_profile.ps1):

Set-Alias git hub

A simple way to do this is to run the following from the PowerShell prompt:

Add-Content $PROFILE "`nSet-Alias git hub"

Note: You'll need to restart your PowerShell console in order for the changes to be picked up.

If your PowerShell profile doesn't exist, you can create it by running the following:

New-Item -Type file -Force $PROFILE

Shell tab-completion

hub repository contains tab-completion scripts for bash, zsh and fish. These scripts complement existing completion scripts that ship with git.

Installation instructions

Meta