refactor: make repository URLs by Repo.Type (currently no change) "currently no change" because only GitHub repos are supported, but more ready to support other types
Alan Pearce alan@alanpearce.eu
Mon, 20 May 2024 23:31:29 +0200
2 files changed, 29 insertions(+), 12 deletions(-)
M internal/importer/package.go → internal/importer/package.go
@@ -225,6 +225,10 @@ if !found { pkgSet = "" } + url, err := makeRepoURL(i.source.Repo, subpath, line) + if err != nil { + errs <- err + } results <- &nix.Package{ Name: i.pkg.Name, Attribute: kv.Key, @@ -239,7 +243,7 @@ MainProgram: i.pkg.Meta.MainProgram, Platforms: i.pkg.Meta.Platforms, Licenses: licenses, Maintainers: maintainers, - Definition: makeRepoURL(i.source.Repo, subpath, line), + Definition: url, } } }()
M internal/importer/utils.go → internal/importer/utils.go
@@ -36,23 +36,36 @@ return "very strange" } -func makeRepoURL(repo config.Repository, subPath string, line string) string { - ref := repo.Revision - if ref == "" { - ref = "master" +func makeRepoURL(repo config.Repository, subPath string, line string) (string, error) { + switch repo.Type { + case config.GitHub: + ref := repo.Revision + if ref == "" { + ref = "master" + } + url, _ := url.JoinPath("https://github.com/", repo.Owner, repo.Repo, "blob", ref, subPath) + if line != "" { + url = url + "#L" + line + } + + return url, nil + default: + return "", errors.Errorf( + "don't know how to generate a repository URL for %s", + repo.Type.String(), + ) } - url, _ := url.JoinPath("https://github.com/", repo.Owner, repo.Repo, "blob", ref, subPath) - if line != "" { - url = url + "#L" + line - } - - return url } func MakeChannelLink(repo config.Repository, subPath string) (*nix.Link, error) { + url, err := makeRepoURL(repo, subPath, "") + if err != nil { + return nil, err + } + return &nix.Link{ Name: fmt.Sprintf("<%s/%s>", repo.Repo, subPath), - URL: makeRepoURL(repo, subPath, ""), + URL: url, }, nil }