A command-line tool that makes git easier to use with GitHub.
Перейти к файлу
Austin Ziegler c4af574b19
Change default protocol to HTTPS (#2939)
Explicitly setting `hub.protocol` to `git` or using `HUB_PROTOCOL=git`
still uses the `git` protocol.

Co-authored-by: Mislav Marohnić <mislav@github.com>
2022-03-25 17:46:40 +01:00
.ctags.d Rename `ctags` file for compatibility with universal-ctags 2018-06-06 14:00:17 +02:00
.github Refresh Actions setup 2022-03-25 16:07:02 +01:00
cmd [cmd] Improve argument display in `--noop` and debug modes 2020-05-26 00:08:16 +02:00
commands Change default protocol to HTTPS (#2939) 2022-03-25 17:46:40 +01:00
coverage Measure code coverage between tests 2018-06-07 14:44:56 +02:00
etc Add more Fish completions to pull-request 2020-03-16 15:38:16 +01:00
features Change default protocol to HTTPS (#2939) 2022-03-25 17:46:40 +01:00
fixtures add /v2 to the module name to resolve the module path problem 2020-04-16 16:30:07 -07:00
git add /v2 to the module name to resolve the module path problem 2020-04-16 16:30:07 -07:00
github Change default protocol to HTTPS (#2939) 2022-03-25 17:46:40 +01:00
internal/assert Add internal/assert package 2020-04-03 16:53:56 +09:00
md2roff Fix tests. 2020-03-20 16:15:41 -07:00
md2roff-bin add /v2 to the module name to resolve the module path problem 2020-04-16 16:30:07 -07:00
script 🔥 remove tracking from documentation site 2020-11-10 12:06:02 +01:00
share Change default protocol to HTTPS (#2939) 2022-03-25 17:46:40 +01:00
ui Fix some Go linting errors 2020-11-17 11:38:14 +01:00
utils Fix parsing boolean flags with explicit values 2020-08-11 17:30:24 +02:00
version hub 2.14.2 2020-03-05 18:48:23 +01:00
.dockerignore [test] Add ability to run tests in a Docker container 2019-10-29 11:06:16 +01:00
.gitattributes Enforce unix eol in bash script files 2017-09-02 20:55:54 +01:00
.gitignore gitignore macOS `.DS_store` files 2020-08-02 18:16:03 +02:00
CODE_OF_CONDUCT.md Improve contact email, part 2 2017-08-28 21:47:08 +02:00
CONTRIBUTING.md add reference to security policy 2021-07-05 11:00:58 +12:00
Dockerfile indent 💅 2020-04-13 12:59:36 +02:00
Gemfile bump aruba 2022-03-25 15:32:48 +01:00
Gemfile.lock bump aruba 2022-03-25 15:32:48 +01:00
LICENSE MIT 2009-12-08 02:13:06 -08:00
Makefile add /v2 to the module name to resolve the module path problem 2020-04-16 16:30:07 -07:00
README.md Change default protocol to HTTPS (#2939) 2022-03-25 17:46:40 +01:00
cucumber.yml Update Cucumber 2019-08-21 17:33:11 +02:00
go.mod go compat 2022-03-25 15:32:48 +01:00
go.sum go compat 2022-03-25 15:32:48 +01:00
main.go go fmt 2022-03-25 16:13:02 +01:00
man-template.html Remove unwanted tracking from distributed HTML man pages 2020-01-21 14:13:17 +01:00

README.md

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.

For an official, potentially more user-friendly command-line interface to GitHub, see cli.github.com and this comparison.

This repository and its issue tracker is not for reporting problems with GitHub.com web interface. If you have a problem with GitHub itself, please contact Support.

Usage

$ hub clone rtomayko/tilt
#=> git clone https://github.com/rtomayko/tilt.git

# or, if you prefer the SSH protocol:
$ git config --global hub.protocol ssh
$ hub clone rtomayko/tilt
#=> git clone git@github.com:rtomayko/tilt.git

See usage examples or the full reference documentation to see all available commands and flags.

hub can also be used to make shell scripts that directly interact with the GitHub API.

hub can be safely aliased as git, so you can type $ git <command> in the shell and have it expanded with hub features.

Installation

The hub executable has no dependencies, but since it was designed to wrap git, it's recommended to have at least git 1.7.3 or newer.

platform manager command to run
macOS, Linux Homebrew brew install hub
macOS, Linux Nix nix-env -i hub
Windows Scoop scoop install hub
Windows Chocolatey choco install hub
Fedora Linux DNF sudo dnf install hub
Arch Linux pacman sudo pacman -S hub
FreeBSD pkg(8) pkg install hub
Debian, Ubuntu apt(8) sudo apt install hub
Ubuntu Snap We do not recommend installing the snap anymore.
openSUSE Zypper sudo zypper install hub
Void Linux xbps sudo xbps-install -S hub
Gentoo Portage sudo emerge dev-vcs/hub
any conda conda install -c conda-forge hub

Packages other than Homebrew are community-maintained (thank you!) and they are not guaranteed to match the latest hub release. Check hub version after installing a community package.

Standalone

hub can be easily installed as an executable. Download the latest binary for your system and put it anywhere in your executable path.

GitHub Actions

hub is ready to be used in your GitHub Actions workflows:

steps:
- uses: actions/checkout@v2

- name: List open pull requests
  run: hub pr list
  env:
    GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

Note that the default secrets.GITHUB_TOKEN will only work for API operations scoped to the repository that runs this workflow. If you need to interact with other repositories, generate a Personal Access Token with at least the repo scope and add it to your repository secrets.

Source

Prerequisites for building from source are:

Clone this repository and run make install:

git clone \
  --config transfer.fsckobjects=false \
  --config receive.fsckobjects=false \
  --config fetch.fsckobjects=false \
  https://github.com/github/hub.git

cd hub
make install prefix=/usr/local

Aliasing

Some hub features feel 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.

Meta