aur_warnings.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  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,
  42. remote map[string]alpm.IPackage, aurData map[string]*aur.Pkg,
  43. ) {
  44. for _, name := range remoteNames {
  45. if _, ok := aurData[name]; !ok && !remote[name].ShouldIgnore() {
  46. if _, ok := aurData[strings.TrimSuffix(name, "-debug")]; !ok {
  47. warnings.Missing = append(warnings.Missing, name)
  48. }
  49. }
  50. }
  51. }
  52. func (warnings *AURWarnings) Print() {
  53. normalMissing, debugMissing := filterDebugPkgs(warnings.Missing)
  54. if len(normalMissing) > 0 {
  55. warnings.log.Warnln(gotext.Get("Packages not in AUR:"), formatNames(normalMissing))
  56. }
  57. if len(debugMissing) > 0 {
  58. warnings.log.Warnln(gotext.Get("Missing AUR Debug Packages:"), formatNames(debugMissing))
  59. }
  60. if len(warnings.Orphans) > 0 {
  61. warnings.log.Warnln(gotext.Get("Orphan (unmaintained) AUR Packages:"), formatNames(warnings.Orphans))
  62. }
  63. if len(warnings.OutOfDate) > 0 {
  64. warnings.log.Warnln(gotext.Get("Flagged Out Of Date AUR Packages:"), formatNames(warnings.OutOfDate))
  65. }
  66. if len(warnings.LocalNewer) > 0 {
  67. for _, newer := range warnings.LocalNewer {
  68. warnings.log.Warnln(newer)
  69. }
  70. }
  71. }
  72. func filterDebugPkgs(names []string) (normal, debug []string) {
  73. normal = make([]string, 0, len(names))
  74. debug = make([]string, 0, len(names))
  75. for _, name := range names {
  76. if strings.HasSuffix(name, "-debug") {
  77. debug = append(debug, name)
  78. } else {
  79. normal = append(normal, name)
  80. }
  81. }
  82. return
  83. }
  84. func formatNames(names []string) string {
  85. return " " + text.Cyan(strings.Join(names, " "))
  86. }