load test
Find a file
Mislav Marohnić ac348b0dec Fix requesting REST sub-resources on GHE
GitHub REST resources typically return full URLs to fetch related
resources at. We used to parse those URLs to find just the path portion
and pass that in to the `REST()` function, which only accepted paths. By
doing so, we are essential de-constructing a URL just to re-assemble it
again. While re-assembling it for Enterprise, though, we would
accidentally inject an extra `api/v3/` prefix where one was not needed.

The solution is just to use raw URLs as reported by the REST API with
no modifications. This extends the `REST()` function to accept full URLs
in addition to just paths to resources.
2021-04-19 12:41:09 +02:00
.github Fix secrets in PR automation being available to PR from forks 2021-04-13 11:10:13 +02:00
.vscode Add VS Code settings 2019-10-07 16:36:23 +02:00
api Fix requesting REST sub-resources on GHE 2021-04-19 12:41:09 +02:00
cmd Merge pull request #3330 from cli/man-gen-test 2021-04-05 14:21:44 -05:00
context Default to GHES host if only GHES is authenticated (#3286) 2021-03-30 16:51:00 +02:00
docs Tweak build scripts to enable cross-compiling 2021-04-09 15:48:12 +02:00
git Add a note about the style of git tests 2021-02-26 13:07:38 +01:00
internal Add tests for quick fix 2021-04-02 08:42:19 -07:00
pkg Fix requesting REST sub-resources on GHE 2021-04-19 12:41:09 +02:00
script Tweak build scripts to enable cross-compiling 2021-04-09 15:48:12 +02:00
test Pass web browser to each individual command 2021-03-19 21:22:37 +01:00
utils Disable preview option in prompts if URL size is too long 2021-03-30 19:12:31 +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 Prevent further use of SetPrepareCmd and InitCmdStubber 2021-01-18 22:44:53 +01:00
.goreleaser.yml Merge remote-tracking branch 'origin/trunk' into arm32 2020-12-14 14:08:26 -08:00
go.mod remove previous emoji workaround 2021-04-12 09:56:00 -07:00
go.sum remove previous emoji workaround 2021-04-12 09:56:00 -07: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 Update scoop install option (#2478) 2020-11-25 11:40:30 +01:00
wix.json Rename "master" to "trunk" in various links 2020-05-26 20:57:26 +02: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

See the manual for setup and usage instructions.

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, 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

Linux

gh is available via Homebrew, and as downloadable binaries from the releases page.

For more information and distro-specific instructions, see the Linux installation docs.

Windows

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

WinGet

Install: Upgrade:
winget install gh winget install gh

WinGet does not have a specialized upgrade command yet, but the install command should work for upgrading to a newer version of GitHub CLI.

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.

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.