2017-08-02 19:24:03 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2021-08-12 18:56:23 +02:00
|
|
|
"context"
|
2017-08-02 19:24:03 +02:00
|
|
|
"fmt"
|
2023-03-08 22:30:54 +01:00
|
|
|
"io"
|
2018-02-19 18:36:33 +01:00
|
|
|
"os"
|
2018-01-26 02:18:49 +01:00
|
|
|
"strconv"
|
2017-08-02 19:24:03 +02:00
|
|
|
|
2021-05-13 07:27:24 +02:00
|
|
|
aur "github.com/Jguer/aur"
|
2023-03-08 22:30:54 +01:00
|
|
|
mapset "github.com/deckarep/golang-set/v2"
|
2020-05-04 09:24:32 +02:00
|
|
|
"github.com/leonelquinteros/gotext"
|
2019-10-16 23:36:08 +02:00
|
|
|
|
2023-03-07 22:04:06 +01:00
|
|
|
"github.com/Jguer/yay/v12/pkg/db"
|
2023-03-08 22:30:54 +01:00
|
|
|
"github.com/Jguer/yay/v12/pkg/dep"
|
2023-03-07 22:04:06 +01:00
|
|
|
"github.com/Jguer/yay/v12/pkg/query"
|
|
|
|
"github.com/Jguer/yay/v12/pkg/settings"
|
|
|
|
"github.com/Jguer/yay/v12/pkg/settings/parser"
|
|
|
|
"github.com/Jguer/yay/v12/pkg/text"
|
|
|
|
"github.com/Jguer/yay/v12/pkg/upgrade"
|
2017-08-02 19:24:03 +02:00
|
|
|
)
|
|
|
|
|
2023-05-24 10:22:18 +02:00
|
|
|
// printInfo prints package info like pacman -Si.
|
|
|
|
func printInfo(config *settings.Configuration, a *aur.Pkg, extendedInfo bool) {
|
2020-05-04 09:24:32 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Repository"), "aur")
|
|
|
|
text.PrintInfoValue(gotext.Get("Name"), a.Name)
|
|
|
|
text.PrintInfoValue(gotext.Get("Version"), a.Version)
|
|
|
|
text.PrintInfoValue(gotext.Get("Description"), a.Description)
|
|
|
|
text.PrintInfoValue(gotext.Get("URL"), a.URL)
|
2020-08-30 23:13:04 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Licenses"), a.License...)
|
2023-08-02 09:45:14 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Groups"), a.Groups...)
|
2020-08-30 23:13:04 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Provides"), a.Provides...)
|
|
|
|
text.PrintInfoValue(gotext.Get("Depends On"), a.Depends...)
|
2023-08-02 09:45:14 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Optional Deps"), a.OptDepends...)
|
2020-08-30 23:13:04 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Make Deps"), a.MakeDepends...)
|
|
|
|
text.PrintInfoValue(gotext.Get("Check Deps"), a.CheckDepends...)
|
|
|
|
text.PrintInfoValue(gotext.Get("Conflicts With"), a.Conflicts...)
|
2023-08-02 09:45:14 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Replaces"), a.Replaces...)
|
|
|
|
text.PrintInfoValue(gotext.Get("AUR URL"), config.AURURL+"/packages/"+a.Name)
|
2020-06-26 09:15:36 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("First Submitted"), text.FormatTimeQuery(a.FirstSubmitted))
|
2023-08-02 09:45:14 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Keywords"), a.Keywords...)
|
2020-06-26 09:15:36 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Last Modified"), text.FormatTimeQuery(a.LastModified))
|
2023-08-02 09:45:14 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Maintainer"), a.Maintainer)
|
|
|
|
text.PrintInfoValue(gotext.Get("Popularity"), fmt.Sprintf("%f", a.Popularity))
|
|
|
|
text.PrintInfoValue(gotext.Get("Votes"), fmt.Sprintf("%d", a.NumVotes))
|
2018-07-24 02:48:36 +02:00
|
|
|
|
2017-08-02 19:24:03 +02:00
|
|
|
if a.OutOfDate != 0 {
|
2020-06-26 09:15:36 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Out-of-date"), text.FormatTimeQuery(a.OutOfDate))
|
2018-05-30 17:00:40 +02:00
|
|
|
} else {
|
2020-05-04 09:24:32 +02:00
|
|
|
text.PrintInfoValue(gotext.Get("Out-of-date"), "No")
|
2017-08-02 19:24:03 +02:00
|
|
|
}
|
2018-01-07 18:36:31 +01:00
|
|
|
|
2020-07-08 03:22:01 +02:00
|
|
|
if extendedInfo {
|
2020-05-04 09:24:32 +02:00
|
|
|
text.PrintInfoValue("ID", fmt.Sprintf("%d", a.ID))
|
|
|
|
text.PrintInfoValue(gotext.Get("Package Base ID"), fmt.Sprintf("%d", a.PackageBaseID))
|
|
|
|
text.PrintInfoValue(gotext.Get("Package Base"), a.PackageBase)
|
|
|
|
text.PrintInfoValue(gotext.Get("Snapshot URL"), config.AURURL+a.URLPath)
|
2018-07-24 02:48:36 +02:00
|
|
|
}
|
|
|
|
|
2018-01-07 18:36:31 +01:00
|
|
|
fmt.Println()
|
2017-08-02 19:24:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// BiggestPackages prints the name of the ten biggest packages in the system.
|
2020-08-16 23:41:38 +02:00
|
|
|
func biggestPackages(dbExecutor db.Executor) {
|
2020-08-04 22:00:07 +02:00
|
|
|
pkgS := dbExecutor.BiggestPackages()
|
2017-08-02 19:24:03 +02:00
|
|
|
|
|
|
|
if len(pkgS) < 10 {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
for i := 0; i < 10; i++ {
|
2020-08-17 00:09:43 +02:00
|
|
|
fmt.Printf("%s: %s\n", text.Bold(pkgS[i].Name()), text.Cyan(text.Human(pkgS[i].ISize())))
|
2017-08-02 19:24:03 +02:00
|
|
|
}
|
|
|
|
}
|
2017-10-19 07:59:26 +02:00
|
|
|
|
|
|
|
// localStatistics prints installed packages statistics.
|
2023-03-05 22:58:18 +01:00
|
|
|
func localStatistics(ctx context.Context, cfg *settings.Configuration, dbExecutor db.Executor) error {
|
|
|
|
info := statistics(cfg, dbExecutor)
|
2017-10-19 07:59:26 +02:00
|
|
|
|
2022-11-20 01:51:55 +01:00
|
|
|
remoteNames := dbExecutor.InstalledRemotePackageNames()
|
2023-05-24 10:22:18 +02:00
|
|
|
remote := dbExecutor.InstalledRemotePackages()
|
2020-05-04 09:24:32 +02:00
|
|
|
text.Infoln(gotext.Get("Yay version v%s", yayVersion))
|
2020-08-17 00:09:43 +02:00
|
|
|
fmt.Println(text.Bold(text.Cyan("===========================================")))
|
|
|
|
text.Infoln(gotext.Get("Total installed packages: %s", text.Cyan(strconv.Itoa(info.Totaln))))
|
2022-02-03 09:58:55 +01:00
|
|
|
text.Infoln(gotext.Get("Foreign installed packages: %s", text.Cyan(strconv.Itoa(len(remoteNames)))))
|
2020-08-17 00:09:43 +02:00
|
|
|
text.Infoln(gotext.Get("Explicitly installed packages: %s", text.Cyan(strconv.Itoa(info.Expln))))
|
|
|
|
text.Infoln(gotext.Get("Total Size occupied by packages: %s", text.Cyan(text.Human(info.TotalSize))))
|
2022-02-06 10:53:34 +01:00
|
|
|
|
|
|
|
for path, size := range info.pacmanCaches {
|
|
|
|
text.Infoln(gotext.Get("Size of pacman cache %s: %s", path, text.Cyan(text.Human(size))))
|
|
|
|
}
|
|
|
|
|
2023-03-05 22:58:18 +01:00
|
|
|
text.Infoln(gotext.Get("Size of yay cache %s: %s", cfg.BuildDir, text.Cyan(text.Human(info.yayCache))))
|
2020-08-17 00:09:43 +02:00
|
|
|
fmt.Println(text.Bold(text.Cyan("===========================================")))
|
2020-05-04 09:24:32 +02:00
|
|
|
text.Infoln(gotext.Get("Ten biggest packages:"))
|
2020-08-04 22:00:07 +02:00
|
|
|
biggestPackages(dbExecutor)
|
2020-08-17 00:09:43 +02:00
|
|
|
fmt.Println(text.Bold(text.Cyan("===========================================")))
|
2017-10-19 07:59:26 +02:00
|
|
|
|
2023-05-24 10:22:18 +02:00
|
|
|
aurData, err := cfg.Runtime.AURClient.Get(ctx, &aur.Query{
|
|
|
|
Needles: remoteNames,
|
|
|
|
By: aur.Name,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
warnings := query.NewWarnings(cfg.Runtime.Logger.Child("print"))
|
|
|
|
for i := range aurData {
|
|
|
|
warnings.AddToWarnings(remote, &aurData[i])
|
|
|
|
}
|
|
|
|
|
|
|
|
warnings.Print()
|
2017-10-19 07:59:26 +02:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2018-01-17 22:48:23 +01:00
|
|
|
|
2023-03-05 22:58:18 +01:00
|
|
|
func printUpdateList(ctx context.Context, cfg *settings.Configuration, cmdArgs *parser.Arguments,
|
2022-11-08 01:32:21 +01:00
|
|
|
dbExecutor db.Executor, enableDowngrade bool, filter upgrade.Filter,
|
|
|
|
) error {
|
2023-03-08 22:30:54 +01:00
|
|
|
quietMode := cmdArgs.ExistsArg("q", "quiet")
|
2023-04-05 13:43:30 +02:00
|
|
|
|
2023-04-04 00:05:45 +02:00
|
|
|
// TODO: handle quiet mode in a better way
|
2023-04-10 18:26:09 +02:00
|
|
|
logger := text.NewLogger(io.Discard, os.Stderr, os.Stdin, cfg.Debug, "update-list")
|
2023-04-04 00:05:45 +02:00
|
|
|
dbExecutor.SetLogger(logger.Child("db"))
|
2023-05-15 10:33:12 +02:00
|
|
|
oldNoConfirm := settings.NoConfirm
|
2023-04-05 13:43:30 +02:00
|
|
|
settings.NoConfirm = true
|
2023-05-15 10:33:12 +02:00
|
|
|
// restoring global NoConfirm to make tests work properly
|
|
|
|
defer func() { settings.NoConfirm = oldNoConfirm }()
|
2021-08-11 20:13:28 +02:00
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
targets := mapset.NewThreadUnsafeSet(cmdArgs.Targets...)
|
2023-05-24 10:22:18 +02:00
|
|
|
grapher := dep.NewGrapher(dbExecutor, cfg.Runtime.AURClient, false, true,
|
2023-03-08 22:30:54 +01:00
|
|
|
false, false, cmdArgs.ExistsArg("needed"), logger.Child("grapher"))
|
2018-04-27 02:25:40 +02:00
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
upService := upgrade.NewUpgradeService(
|
2023-05-24 10:22:18 +02:00
|
|
|
grapher, cfg.Runtime.AURClient, dbExecutor, cfg.Runtime.VCSStore,
|
2023-04-05 13:43:30 +02:00
|
|
|
cfg, true, logger.Child("upgrade"))
|
2021-08-11 20:13:28 +02:00
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
graph, errSysUp := upService.GraphUpgrades(ctx, nil,
|
|
|
|
enableDowngrade, filter)
|
|
|
|
if errSysUp != nil {
|
|
|
|
return errSysUp
|
2018-01-25 21:39:26 +01:00
|
|
|
}
|
2018-03-21 05:50:54 +01:00
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
if graph.Len() == 0 {
|
2023-02-21 03:00:39 +01:00
|
|
|
return fmt.Errorf("")
|
|
|
|
}
|
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
noTargets := targets.Cardinality() == 0
|
|
|
|
foreignFilter := cmdArgs.ExistsArg("m", "foreign")
|
|
|
|
nativeFilter := cmdArgs.ExistsArg("n", "native")
|
2018-03-21 05:50:54 +01:00
|
|
|
|
2023-05-22 20:35:27 +02:00
|
|
|
noUpdates := true
|
2023-03-08 22:30:54 +01:00
|
|
|
_ = graph.ForEach(func(pkgName string, ii *dep.InstallInfo) error {
|
2023-04-06 18:32:22 +02:00
|
|
|
if !ii.Upgrade {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
if noTargets || targets.Contains(pkgName) {
|
|
|
|
if ii.Source == dep.Sync && foreignFilter {
|
|
|
|
return nil
|
|
|
|
} else if ii.Source == dep.AUR && nativeFilter {
|
|
|
|
return nil
|
2018-03-21 05:50:54 +01:00
|
|
|
}
|
2021-08-11 20:13:28 +02:00
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
if quietMode {
|
|
|
|
fmt.Printf("%s\n", pkgName)
|
|
|
|
} else {
|
2023-04-04 00:05:45 +02:00
|
|
|
fmt.Printf("%s %s -> %s\n", text.Bold(pkgName), text.Bold(text.Green(ii.LocalVersion)),
|
|
|
|
text.Bold(text.Green(ii.Version)))
|
2018-03-21 05:50:54 +01:00
|
|
|
}
|
2018-01-25 21:39:26 +01:00
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
targets.Remove(pkgName)
|
2023-05-22 20:35:27 +02:00
|
|
|
noUpdates = false
|
2018-03-23 20:49:51 +01:00
|
|
|
}
|
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
return nil
|
|
|
|
})
|
2018-03-23 20:49:51 +01:00
|
|
|
|
2023-03-08 22:30:54 +01:00
|
|
|
missing := false
|
|
|
|
targets.Each(func(pkgName string) bool {
|
|
|
|
if dbExecutor.LocalPackage(pkgName) == nil {
|
|
|
|
cfg.Runtime.Logger.Errorln(gotext.Get("package '%s' was not found", pkgName))
|
|
|
|
missing = true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
})
|
2018-03-23 20:49:51 +01:00
|
|
|
|
2023-05-22 20:35:27 +02:00
|
|
|
if missing || noUpdates {
|
2018-03-23 20:49:51 +01:00
|
|
|
return fmt.Errorf("")
|
2018-01-25 21:39:26 +01:00
|
|
|
}
|
2018-02-19 18:36:33 +01:00
|
|
|
|
2018-01-25 21:39:26 +01:00
|
|
|
return nil
|
|
|
|
}
|