123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- package main // import "github.com/Jguer/yay"
- import (
- "context"
- "errors"
- "os"
- "os/exec"
- "runtime/debug"
- "github.com/leonelquinteros/gotext"
- "github.com/Jguer/yay/v12/pkg/db/ialpm"
- "github.com/Jguer/yay/v12/pkg/runtime"
- "github.com/Jguer/yay/v12/pkg/settings"
- "github.com/Jguer/yay/v12/pkg/settings/parser"
- "github.com/Jguer/yay/v12/pkg/text"
- )
- var (
- yayVersion = "12.0.4" // To be set by compiler.
- localePath = "/usr/share/locale" // To be set by compiler.
- )
- func initGotext() {
- if envLocalePath := os.Getenv("LOCALE_PATH"); envLocalePath != "" {
- localePath = envLocalePath
- }
- if lc := os.Getenv("LANGUAGE"); lc != "" {
- gotext.Configure(localePath, lc, "yay")
- } else if lc := os.Getenv("LC_ALL"); lc != "" {
- gotext.Configure(localePath, lc, "yay")
- } else if lc := os.Getenv("LC_MESSAGES"); lc != "" {
- gotext.Configure(localePath, lc, "yay")
- } else {
- gotext.Configure(localePath, os.Getenv("LANG"), "yay")
- }
- }
- func main() {
- fallbackLog := text.NewLogger(os.Stdout, os.Stderr, os.Stdin, false, "fallback")
- var (
- err error
- ctx = context.Background()
- ret = 0
- )
- defer func() {
- if rec := recover(); rec != nil {
- fallbackLog.Errorln(rec)
- debug.PrintStack()
- }
- os.Exit(ret)
- }()
- initGotext()
- if os.Geteuid() == 0 {
- fallbackLog.Warnln(gotext.Get("Avoid running yay as root/sudo."))
- }
- configPath := settings.GetConfigPath()
- // Parse config
- cfg, err := settings.NewConfig(fallbackLog, configPath, yayVersion)
- if err != nil {
- if str := err.Error(); str != "" {
- fallbackLog.Errorln(str)
- }
- ret = 1
- return
- }
- if errS := cfg.RunMigrations(fallbackLog,
- settings.DefaultMigrations(), configPath, yayVersion); errS != nil {
- fallbackLog.Errorln(errS)
- }
- cmdArgs := parser.MakeArguments()
- // Parse command line
- if err = cfg.ParseCommandLine(cmdArgs); err != nil {
- if str := err.Error(); str != "" {
- fallbackLog.Errorln(str)
- }
- ret = 1
- return
- }
- if cfg.SaveConfig {
- if errS := cfg.Save(configPath, yayVersion); errS != nil {
- fallbackLog.Errorln(errS)
- }
- }
- // Build run
- run, err := runtime.NewRuntime(cfg, cmdArgs, yayVersion)
- if err != nil {
- if str := err.Error(); str != "" {
- fallbackLog.Errorln(str)
- }
- ret = 1
- return
- }
- dbExecutor, err := ialpm.NewExecutor(run.PacmanConf, run.Logger.Child("db"))
- if err != nil {
- if str := err.Error(); str != "" {
- fallbackLog.Errorln(str)
- }
- ret = 1
- return
- }
- defer func() {
- if rec := recover(); rec != nil {
- fallbackLog.Errorln(rec, string(debug.Stack()))
- }
- dbExecutor.Cleanup()
- }()
- if err = handleCmd(ctx, run, cmdArgs, dbExecutor); err != nil {
- if str := err.Error(); str != "" {
- fallbackLog.Errorln(str)
- if cmdArgs.ExistsArg("c") && cmdArgs.ExistsArg("y") && cmdArgs.Op == "S" {
- // Remove after 2023-10-01
- fallbackLog.Errorln("Did you mean 'yay -Yc'?")
- }
- }
- exitError := &exec.ExitError{}
- if errors.As(err, &exitError) {
- // mirror pacman exit code when applicable
- ret = exitError.ExitCode()
- return
- }
- // fallback
- ret = 1
- }
- }
|