internal/postgres: change versions sort order

In getPath versions, sort first by version,then by module path.

Module path came first in order to group results by module when a package
appears in more than one module. But it also results in out-of-order
versions, because v11 sorts before v2. Now we only use the module path
to break ties when versions are the same.

Incompatible versions still come last.

Fixes #79632.

Change-Id: I1b66135685a0b36478bb0380da03e515ae64b4cb
Reviewed-on: https://go-review.googlesource.com/c/pkgsite/+/784460
LUCI-TryBot-Result: golang-scoped@luci-project-accounts.iam.gserviceaccount.com <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Hyang-Ah Hana Kim <hyangah@gmail.com>
kokoro-CI: kokoro <noreply+kokoro@google.com>
2 files changed
tree: 8670a5839bbffe4ba590d4ef0249bb26f3944b7d
  1. .github/
  2. cmd/
  3. deploy/
  4. devtools/
  5. doc/
  6. internal/
  7. migrations/
  8. static/
  9. tests/
  10. third_party/
  11. .dockerignore
  12. .gitignore
  13. .prettierignore
  14. .prettierrc.yaml
  15. .stylelintignore
  16. .stylelintrc.yaml
  17. all.bash
  18. codereview.cfg
  19. CONTRIBUTING.md
  20. eslint.config.js
  21. go.mod
  22. go.sum
  23. jest.config.js
  24. LICENSE
  25. package-lock.json
  26. package.json
  27. PATENTS
  28. README.md
  29. tsconfig.json
README.md

golang.org/x/pkgsite

This repository hosts the source code of the pkg.go.dev website, and pkgsite, a documentation server program.

Go Reference

pkg.go.dev: a site for discovering Go packages

Pkg.go.dev is a website for discovering and evaluating Go packages and modules.

You can check it out at https://pkg.go.dev.

pkgsite: a documentation server

pkgsite program extracts and generates documentation for Go projects.

Example usage:

$ go install golang.org/x/pkgsite/cmd/pkgsite@latest
$ cd myproject
$ pkgsite -open .

For more information, see the pkgsite documentation.

API

pkgsite provides a REST API for retrieving package and module information. Currently the API is on v1beta, but after a periodic of community feedback we will transition to v1. The API endpoints include:

  • /v1beta/package/{path}: Information about the package at {path}.
  • /v1beta/module/{path}: Information about the module at {path}.
  • /v1beta/versions/{path}: Versions of the module at {path}.
  • /v1beta/packages/{path}: Information about packages of the module at {path}.
  • /v1beta/search: Search results.
  • /v1beta/symbols/{path}: List of symbols for the package at {path}.
  • /v1beta/imported-by/{path}: Paths of packages importing the package at {path}.
  • /v1beta/vulns/{path}: Vulnerabilities of the module at {path}.

For detailed documentation of parameters and response schemas, see the documentation page served at /api, or refer directly to the annotated source code in internal/api/api.go.

Issues

If you want to report a bug or have a feature suggestion, please first check the known issues to see if your issue is already being discussed. If an issue does not already exist, feel free to file an issue.

For answers to frequently asked questions, see pkg.go.dev/about.

You can also chat with us on the #pkgsite Slack channel on the Gophers Slack.

Contributing

We would love your help!

Our canonical Git repository is located at go.googlesource.com/pkgsite. There is a mirror of the repository at github.com/golang/pkgsite.

To contribute, please read our contributing guide.

License

Unless otherwise noted, the Go source files are distributed under the BSD-style license found in the LICENSE file.

Links