load test
Find a file
Mislav Marohnić 36ffbe18de
Improve looking up draft releases by tag name
This changes the FetchRelease implementation to look up draft releases directly using by its pending tag name, as opposed to resorting to the Releases list API which is backed by Elastic Search and thus suffers replication lag after the creation of a draft release.

Bonus: all release lookup functions now accept a context for cancellation.
2022-12-14 21:24:08 +01:00
.devcontainer Update to Go 1.19 2022-12-12 15:50:13 +01:00
.github Bump goreleaser/goreleaser-action from 3 to 4 2022-12-13 14:03:54 +00:00
api Improve looking up draft releases by tag name 2022-12-14 21:24:08 +01:00
build/windows Resolve PR feedback 2021-09-18 09:23:43 -07:00
cmd Merge pull request #6421 from cli/go-gh-term 2022-11-03 13:02:24 +01:00
context revert revert 57fbe4f317 (#6474) 2022-10-20 12:17:20 +00:00
docs Update to Go 1.19 2022-12-12 15:50:13 +01:00
git Authenticate network git commands (#6541) 2022-11-15 13:14:37 +02:00
internal Merge pull request #6711 from cli/release-prompter 2022-12-12 12:09:29 -06:00
pkg Improve looking up draft releases by tag name 2022-12-14 21:24:08 +01:00
script Remove pubkey as it is no longer necessary (#6208) 2022-09-06 14:31:24 +00:00
test Pass web browser to each individual command 2021-03-19 21:22:37 +01:00
utils Merge remote-tracking branch 'origin' into go-gh-term 2022-10-24 17:07:24 +02:00
.gitattributes Retire copy-release-to-another-repo action 2020-01-29 16:13:07 +01:00
.gitignore Port select portions of Makefile to script/build.go 2021-01-08 22:35:57 +01:00
.golangci.yml Re-enable linters now that golangci-lint has been updated (#5615) 2022-05-11 16:57:57 +02:00
.goreleaser.yml Fix up bindir for new version of goreleaser (#6621) 2022-11-15 11:40:30 +02:00
CODEOWNERS Fix CODEOWNERS for codespaces 2021-11-15 20:05:54 +01:00
go.mod bump safeexec for 1.19 fix 2022-12-12 16:48:25 +01:00
go.sum bump safeexec for 1.19 fix 2022-12-12 16:48:25 +01:00
LICENSE Create LICENSE 2019-11-21 13:22:23 -06:00
Makefile Tweak build scripts to enable cross-compiling 2021-04-09 15:48:12 +02:00
README.md docs: Update installation instructions for WinGet (#6716) 2022-12-12 13:38:56 +00:00

GitHub CLI

gh is GitHub on the command line. It brings pull requests, issues, and other GitHub concepts to the terminal next to where you are already working with git and your code.

screenshot of gh pr status

GitHub CLI is available for repositories hosted on GitHub.com and GitHub Enterprise Server 2.20+, and to install on macOS, Windows, and Linux.

Documentation

For installation options see below, for usage instructions see the manual.

Contributing

If anything feels off, or if you feel that some functionality is missing, please check out the contributing page. There you will find instructions for sharing your feedback, building the tool locally, and submitting pull requests to the project.

Installation

macOS

gh is available via Homebrew, MacPorts, Conda, Spack, and as a downloadable binary from the releases page.

Homebrew

Install: Upgrade:
brew install gh brew upgrade gh

MacPorts

Install: Upgrade:
sudo port install gh sudo port selfupdate && sudo port upgrade gh

Conda

Install: Upgrade:
conda install gh --channel conda-forge conda update gh --channel conda-forge

Additional Conda installation options available on the gh-feedstock page.

Spack

Install: Upgrade:
spack install gh spack uninstall gh && spack install gh

Linux & BSD

gh is available via:

For more information, see Linux & BSD installation.

Windows

gh is available via WinGet, scoop, Chocolatey, Conda, and as downloadable MSI.

WinGet

Install: Upgrade:
winget install --id GitHub.cli winget upgrade --id GitHub.cli

Note


The Windows installer modifes your PATH. When using Windows Terminal, you will need to open a new window for the changes to take affect. (Simply opening a new tab will not be sufficient.)

scoop

Install: Upgrade:
scoop install gh scoop update gh

Chocolatey

Install: Upgrade:
choco install gh choco upgrade gh

Signed MSI

MSI installers are available for download on the releases page.

Codespaces

To add GitHub CLI to your codespace, add the following to your devcontainer file:

"features": {
  "github-cli": "latest"
}

GitHub Actions

GitHub CLI comes pre-installed in all GitHub-Hosted Runners.

Other platforms

Download packaged binaries from the releases page.

Build from source

See here on how to build GitHub CLI from source.

Comparison with hub

For many years, hub was the unofficial GitHub CLI tool. gh is a new project that helps us explore what an official GitHub CLI tool can look like with a fundamentally different design. While both tools bring GitHub to the terminal, hub behaves as a proxy to git, and gh is a standalone tool. Check out our more detailed explanation to learn more.