aur_warnings.go 2.6 KB

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