aur_warnings.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package query
  2. import (
  3. "strings"
  4. "github.com/leonelquinteros/gotext"
  5. "github.com/Jguer/aur"
  6. "github.com/Jguer/go-alpm/v2"
  7. "github.com/Jguer/yay/v12/pkg/db"
  8. "github.com/Jguer/yay/v12/pkg/text"
  9. )
  10. type AURWarnings struct {
  11. Orphans []string
  12. OutOfDate []string
  13. Missing []string
  14. LocalNewer []string
  15. log *text.Logger
  16. }
  17. func NewWarnings(logger *text.Logger) *AURWarnings {
  18. return &AURWarnings{log: logger}
  19. }
  20. func (warnings *AURWarnings) AddToWarnings(remote map[string]alpm.IPackage, aurPkg *aur.Pkg) {
  21. name := aurPkg.Name
  22. pkg, ok := remote[name]
  23. if !ok {
  24. return
  25. }
  26. if aurPkg.Maintainer == "" && !pkg.ShouldIgnore() {
  27. warnings.Orphans = append(warnings.Orphans, name)
  28. }
  29. if aurPkg.OutOfDate != 0 && !pkg.ShouldIgnore() {
  30. warnings.OutOfDate = append(warnings.OutOfDate, name)
  31. }
  32. if !pkg.ShouldIgnore() && !isDevelPackage(pkg) && db.VerCmp(pkg.Version(), aurPkg.Version) > 0 {
  33. left, right := GetVersionDiff(pkg.Version(), aurPkg.Version)
  34. newerMsg := gotext.Get("%s: local (%s) is newer than AUR (%s)",
  35. text.Cyan(name),
  36. left, right,
  37. )
  38. warnings.LocalNewer = append(warnings.LocalNewer, newerMsg)
  39. }
  40. }
  41. func (warnings *AURWarnings) CalculateMissing(remoteNames []string, remote map[string]alpm.IPackage, aurData map[string]*aur.Pkg) {
  42. for _, name := range remoteNames {
  43. if _, ok := aurData[name]; !ok && !remote[name].ShouldIgnore() {
  44. warnings.Missing = append(warnings.Missing, name)
  45. }
  46. }
  47. }
  48. func (warnings *AURWarnings) Print() {
  49. normalMissing, debugMissing := filterDebugPkgs(warnings.Missing)
  50. if len(normalMissing) > 0 {
  51. warnings.log.Warnln(gotext.Get("Packages not in AUR:"), formatNames(normalMissing))
  52. }
  53. if len(debugMissing) > 0 {
  54. warnings.log.Warnln(gotext.Get("Missing AUR Debug Packages:"), formatNames(debugMissing))
  55. }
  56. if len(warnings.Orphans) > 0 {
  57. warnings.log.Warnln(gotext.Get("Orphan (unmaintained) AUR Packages:"), formatNames(warnings.Orphans))
  58. }
  59. if len(warnings.OutOfDate) > 0 {
  60. warnings.log.Warnln(gotext.Get("Flagged Out Of Date AUR Packages:"), formatNames(warnings.OutOfDate))
  61. }
  62. if len(warnings.LocalNewer) > 0 {
  63. for _, newer := range warnings.LocalNewer {
  64. warnings.log.Warnln(newer)
  65. }
  66. }
  67. }
  68. func filterDebugPkgs(names []string) (normal, debug []string) {
  69. normal = make([]string, 0, len(names))
  70. debug = make([]string, 0, len(names))
  71. for _, name := range names {
  72. if strings.HasSuffix(name, "-debug") {
  73. debug = append(debug, name)
  74. } else {
  75. normal = append(normal, name)
  76. }
  77. }
  78. return
  79. }
  80. func formatNames(names []string) string {
  81. return " " + text.Cyan(strings.Join(names, " "))
  82. }