2020-07-10 02:36:45 +02:00
|
|
|
package query
|
|
|
|
|
|
|
|
import (
|
2021-05-13 07:27:24 +02:00
|
|
|
"context"
|
2020-07-10 02:36:45 +02:00
|
|
|
"sync"
|
|
|
|
|
2021-05-13 07:27:24 +02:00
|
|
|
"github.com/Jguer/aur"
|
2020-07-10 02:36:45 +02:00
|
|
|
"github.com/leonelquinteros/gotext"
|
|
|
|
|
|
|
|
"github.com/Jguer/yay/v10/pkg/intrange"
|
|
|
|
"github.com/Jguer/yay/v10/pkg/multierror"
|
|
|
|
"github.com/Jguer/yay/v10/pkg/text"
|
|
|
|
)
|
|
|
|
|
2021-05-13 07:27:24 +02:00
|
|
|
type Pkg = aur.Pkg
|
2021-02-16 16:10:04 +01:00
|
|
|
|
2020-07-10 02:36:45 +02:00
|
|
|
// Queries the aur for information about specified packages.
|
2021-05-13 07:27:24 +02:00
|
|
|
// All packages should be queried in a single aur request except when the number
|
2020-07-10 02:36:45 +02:00
|
|
|
// of packages exceeds the number set in config.RequestSplitN.
|
2021-05-13 07:27:24 +02:00
|
|
|
// If the number does exceed config.RequestSplitN multiple aur requests will be
|
2020-07-10 02:36:45 +02:00
|
|
|
// performed concurrently.
|
2021-05-13 07:27:24 +02:00
|
|
|
func AURInfo(aurClient *aur.Client, names []string, warnings *AURWarnings, splitN int) ([]*Pkg, error) {
|
2021-02-16 16:10:04 +01:00
|
|
|
info := make([]*Pkg, 0, len(names))
|
2020-07-10 02:36:45 +02:00
|
|
|
seen := make(map[string]int)
|
|
|
|
var mux sync.Mutex
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
var errs multierror.MultiError
|
|
|
|
|
|
|
|
makeRequest := func(n, max int) {
|
|
|
|
defer wg.Done()
|
2021-05-13 07:27:24 +02:00
|
|
|
tempInfo, requestErr := aurClient.Info(context.Background(), names[n:max])
|
2020-07-10 02:36:45 +02:00
|
|
|
errs.Add(requestErr)
|
|
|
|
if requestErr != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
mux.Lock()
|
|
|
|
for i := range tempInfo {
|
|
|
|
info = append(info, &tempInfo[i])
|
|
|
|
}
|
|
|
|
mux.Unlock()
|
|
|
|
}
|
|
|
|
|
|
|
|
for n := 0; n < len(names); n += splitN {
|
|
|
|
max := intrange.Min(len(names), n+splitN)
|
|
|
|
wg.Add(1)
|
|
|
|
go makeRequest(n, max)
|
|
|
|
}
|
|
|
|
|
|
|
|
wg.Wait()
|
|
|
|
|
|
|
|
if err := errs.Return(); err != nil {
|
|
|
|
return info, err
|
|
|
|
}
|
|
|
|
|
|
|
|
for k, pkg := range info {
|
|
|
|
seen[pkg.Name] = k
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, name := range names {
|
|
|
|
i, ok := seen[name]
|
|
|
|
if !ok && !warnings.Ignore.Get(name) {
|
|
|
|
warnings.Missing = append(warnings.Missing, name)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
pkg := info[i]
|
|
|
|
|
|
|
|
if pkg.Maintainer == "" && !warnings.Ignore.Get(name) {
|
|
|
|
warnings.Orphans = append(warnings.Orphans, name)
|
|
|
|
}
|
|
|
|
if pkg.OutOfDate != 0 && !warnings.Ignore.Get(name) {
|
|
|
|
warnings.OutOfDate = append(warnings.OutOfDate, name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return info, nil
|
|
|
|
}
|
|
|
|
|
2021-05-13 07:27:24 +02:00
|
|
|
func AURInfoPrint(aurClient *aur.Client, names []string, splitN int) ([]*Pkg, error) {
|
2020-07-10 02:36:45 +02:00
|
|
|
text.OperationInfoln(gotext.Get("Querying AUR..."))
|
|
|
|
|
|
|
|
warnings := &AURWarnings{}
|
2021-05-13 07:27:24 +02:00
|
|
|
info, err := AURInfo(aurClient, names, warnings, splitN)
|
2020-07-10 02:36:45 +02:00
|
|
|
if err != nil {
|
|
|
|
return info, err
|
|
|
|
}
|
|
|
|
|
|
|
|
warnings.Print()
|
|
|
|
|
|
|
|
return info, nil
|
|
|
|
}
|