Skip to content

Commit

Permalink
Revert "feat: enable relative path ssh URL"
Browse files Browse the repository at this point in the history
  • Loading branch information
Songmu authored Apr 10, 2024
1 parent f18c54e commit cef2d00
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 28 deletions.
16 changes: 6 additions & 10 deletions url.go
Original file line number Diff line number Diff line change
Expand Up @@ -112,16 +112,12 @@ func newURL(ref string, ssh, forceMe bool) (*url.URL, error) {
user := matched[1]
host := matched[2]
path := matched[3]
// When two conditions below are satisfied:
// 1. the path is a relative path, which not beginning with a slash, like `path/to/repo`.
// 2. the host is not github.com, which doesn't support relative paths.
// then we convert the given SCP style URL to a normal style and relative path URL using tilde, like `ssh://user@repo.example.com/~/path/to/repo`.
if strings.HasPrefix(path, "/") {
path = strings.TrimPrefix(path, "/")
} else if host != "github.com" {
path = "~/" + path
}
ref = fmt.Sprintf("ssh://%s%s/%s", user, host, path)
// If the path is a relative path not beginning with a slash like
// `path/to/repo`, we might convert to like
// `ssh://user@repo.example.com/~/path/to/repo` using tilde, but
// since GitHub doesn't support it, we treat relative and absolute
// paths the same way.
ref = fmt.Sprintf("ssh://%s%s/%s", user, host, strings.TrimPrefix(path, "/"))
} else {
// If ref is like "github.com/motemen/ghq" convert to "https://github.com/motemen/ghq"
paths := strings.Split(ref, "/")
Expand Down
21 changes: 3 additions & 18 deletions url_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,35 +20,20 @@ func TestNewURL(t *testing.T) {
expect: "https://github.com/motemen/pusheen-explorer",
host: "github.com",
}, {
name: "scp to github", // Convert SCP-like URL to SSH URL
name: "scp", // Convert SCP-like URL to SSH URL
url: "git@github.com:motemen/pusheen-explorer.git",
expect: "ssh://git@github.com/motemen/pusheen-explorer.git",
host: "github.com",
}, {
name: "scp with root to github",
name: "scp with root",
url: "git@github.com:/motemen/pusheen-explorer.git",
expect: "ssh://git@github.com/motemen/pusheen-explorer.git",
host: "github.com",
}, {
name: "scp without user to github",
name: "scp without user",
url: "github.com:motemen/pusheen-explorer.git",
expect: "ssh://github.com/motemen/pusheen-explorer.git",
host: "github.com",
}, {
name: "scp to others",
url: "git@example.com:repo/www.git",
expect: "ssh://git@example.com/~/repo/www.git",
host: "example.com",
}, {
name: "scp with root to others",
url: "git@example.com:/repo/www.git",
expect: "ssh://git@example.com/repo/www.git",
host: "example.com",
}, {
name: "scp without user to others",
url: "example.com:repo/www.git",
expect: "ssh://example.com/~/repo/www.git",
host: "example.com",
}, {
name: "different name repository",
url: "motemen/ghq",
Expand Down

0 comments on commit cef2d00

Please sign in to comment.