aur_warnings.go 2.7 KB

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