Skip to content

Latest commit

 

History

History
155 lines (98 loc) · 3.87 KB

git-open.1.md

File metadata and controls

155 lines (98 loc) · 3.87 KB

git-open - Open the repository's website in your browser.

SYNOPSIS

git open [--issue] [--commit] [remote-name] [branch-name]

DESCRIPTION

git open opens the repository's website in your browser. The major well known git hosting services are supported.

OPTIONS

-c, --commit Open the current commit. See EXAMPLES for more information. Only tested with GitHub & GitLab.

-i, --issue Open the current issue. When the name of the current branch matches the right pattern, it will open the webpage with that issue. See EXAMPLES for more information. This only works on GitHub, GitLab, Visual Studio Team Services and Team Foundation Server at the moment.

-p, --print Just print the URL. Do not open it in browser.

-h Show a short help text.

EXAMPLES

git open

It opens https://github.com/TRACKED_REMOTE_USER/CURRENT_REPO/

git open someremote

It opens https://github.com/PROVIDED_REMOTE_USER/CURRENT_REPO/

git open someremote somebranch

It opens https://github.com/PROVIDED_REMOTE_USER/CURRENT_REPO/tree/PROVIDED_BRANCH

git open --issue

If branches use naming convention of issues/#123, it opens https://github.com/TRACKED_REMOTE_USER/CURRENT_REPO/issues/123

git open --print

It prints the URL https://github.com/TRACKED_REMOTE_USER/CURRENT_REPO/

git open --commit

Supposing that the current sha is 2ddc8d4548d0cee3d714dcf0068dbec5b168a9b2, it opens https://github.com/TRACKED_REMOTE_USER/CURRENT_REPO/commit/2ddc8d4548d0cee3d714dcf0068dbec5b168a9b2

SUPPORTED GIT HOSTING SERVICES

git-open can automatically guess the corresponding repository page for remotes on the following git hosting services:

  • github.com
  • gist.github.com
  • gitlab.com
  • GitLab CE/EE (self hosted GitLab, see CONFIGURATION)
  • bitbucket.org
  • Atlassian Bitbucket Server (formerly Atlassian Stash)
  • Visual Studio Team Services
  • Team Foundation Server (on-premises)

CONFIGURATION

To configure git-open you may need to set some git config options. You can use --global to set across all repos, instead of just the current repo.

git config [--global] option value

Configuring which remote to open

By default, git open opens the remote named origin. However, if your current branch is remotely-tracking a different remote, that tracked remote will be used.

In some instances, you may want to override this behavior. When you fork a project and add a remote named upstream you often want that upstream to be opened rather than your fork. To accomplish this, you can set the open.default.remote within your project:

git config open.default.remote upstream

This is equivalent to always typing git open upstream.

GitLab options

To configure GitLab support (or other unique hosting situations) you may need to set some options.

open.[gitdomain].domain The (web) domain to open based on the provided git repo domain.

open.[gitdomain].protocol The (web) protocol to open based on the provided git repo domain. Defaults to https.

git config [--global] open.[gitdomain].domain [value]
git config [--global] open.[gitdomain].protocol [value]

Example

  • Your git remote is at ssh://[email protected]:7000/XXX/YYY.git
  • Your hosted gitlab is http://repo.intranet/subpath/XXX/YYY
git config [--global] "open.https://git.internal.biz.domain" "repo.intranet/subpath"
git config [--global] "open.https://git.internal.biz.protocol" "http"

DEBUGGING

You can run git-open in echo mode, which doesn't open your browser, but just prints the URL to stdout:

env BROWSER='echo' ./git-open

AUTHORS

Jason McCreary did the initial hard work. Paul Irish based his project on his work. Since then many contributors have submitted great PRs.

SEE ALSO

git(1), git-remote(1), git-config(1), Project page