aur_info.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package query
  2. import (
  3. "context"
  4. "sync"
  5. "github.com/Jguer/aur"
  6. "github.com/leonelquinteros/gotext"
  7. "github.com/Jguer/yay/v11/pkg/intrange"
  8. "github.com/Jguer/yay/v11/pkg/multierror"
  9. "github.com/Jguer/yay/v11/pkg/text"
  10. )
  11. type Pkg = aur.Pkg
  12. // Queries the aur for information about specified packages.
  13. // All packages should be queried in a single aur request except when the number
  14. // of packages exceeds the number set in config.RequestSplitN.
  15. // If the number does exceed config.RequestSplitN multiple aur requests will be
  16. // performed concurrently.
  17. func AURInfo(ctx context.Context, aurClient aur.ClientInterface, names []string, warnings *AURWarnings, splitN int) ([]Pkg, error) {
  18. info := make([]Pkg, 0, len(names))
  19. seen := make(map[string]int)
  20. var (
  21. mux sync.Mutex
  22. wg sync.WaitGroup
  23. errs multierror.MultiError
  24. )
  25. makeRequest := func(n, max int) {
  26. defer wg.Done()
  27. text.Debugln("AUR RPC:", names[n:max])
  28. tempInfo, requestErr := aurClient.Info(ctx, names[n:max])
  29. if requestErr != nil {
  30. errs.Add(requestErr)
  31. return
  32. }
  33. mux.Lock()
  34. for i := range tempInfo {
  35. info = append(info, tempInfo[i])
  36. }
  37. mux.Unlock()
  38. }
  39. for n := 0; n < len(names); n += splitN {
  40. max := intrange.Min(len(names), n+splitN)
  41. wg.Add(1)
  42. go makeRequest(n, max)
  43. }
  44. wg.Wait()
  45. if err := errs.Return(); err != nil {
  46. return info, err
  47. }
  48. for k := range info {
  49. seen[info[k].Name] = k
  50. }
  51. for _, name := range names {
  52. i, ok := seen[name]
  53. if !ok && !warnings.Ignore.Get(name) {
  54. warnings.Missing = append(warnings.Missing, name)
  55. continue
  56. }
  57. pkg := info[i]
  58. if pkg.Maintainer == "" && !warnings.Ignore.Get(name) {
  59. warnings.Orphans = append(warnings.Orphans, name)
  60. }
  61. if pkg.OutOfDate != 0 && !warnings.Ignore.Get(name) {
  62. warnings.OutOfDate = append(warnings.OutOfDate, name)
  63. }
  64. }
  65. return info, nil
  66. }
  67. func AURInfoPrint(ctx context.Context, aurClient aur.ClientInterface, names []string, splitN int) ([]Pkg, error) {
  68. text.OperationInfoln(gotext.Get("Querying AUR..."))
  69. warnings := &AURWarnings{}
  70. info, err := AURInfo(ctx, aurClient, names, warnings, splitN)
  71. if err != nil {
  72. return info, err
  73. }
  74. warnings.Print()
  75. return info, nil
  76. }