main.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. package main // import "github.com/Jguer/yay"
  2. import (
  3. "context"
  4. "errors"
  5. "os"
  6. "os/exec"
  7. "runtime/debug"
  8. "github.com/leonelquinteros/gotext"
  9. "github.com/Jguer/yay/v12/pkg/db/ialpm"
  10. "github.com/Jguer/yay/v12/pkg/runtime"
  11. "github.com/Jguer/yay/v12/pkg/settings"
  12. "github.com/Jguer/yay/v12/pkg/settings/parser"
  13. "github.com/Jguer/yay/v12/pkg/text"
  14. )
  15. var (
  16. yayVersion = "12.0.4" // To be set by compiler.
  17. localePath = "/usr/share/locale" // To be set by compiler.
  18. )
  19. func initGotext() {
  20. if envLocalePath := os.Getenv("LOCALE_PATH"); envLocalePath != "" {
  21. localePath = envLocalePath
  22. }
  23. if lc := os.Getenv("LANGUAGE"); lc != "" {
  24. gotext.Configure(localePath, lc, "yay")
  25. } else if lc := os.Getenv("LC_ALL"); lc != "" {
  26. gotext.Configure(localePath, lc, "yay")
  27. } else if lc := os.Getenv("LC_MESSAGES"); lc != "" {
  28. gotext.Configure(localePath, lc, "yay")
  29. } else {
  30. gotext.Configure(localePath, os.Getenv("LANG"), "yay")
  31. }
  32. }
  33. func main() {
  34. fallbackLog := text.NewLogger(os.Stdout, os.Stderr, os.Stdin, false, "fallback")
  35. var (
  36. err error
  37. ctx = context.Background()
  38. ret = 0
  39. )
  40. defer func() {
  41. if rec := recover(); rec != nil {
  42. fallbackLog.Errorln(rec)
  43. debug.PrintStack()
  44. }
  45. os.Exit(ret)
  46. }()
  47. initGotext()
  48. if os.Geteuid() == 0 {
  49. fallbackLog.Warnln(gotext.Get("Avoid running yay as root/sudo."))
  50. }
  51. configPath := settings.GetConfigPath()
  52. // Parse config
  53. cfg, err := settings.NewConfig(fallbackLog, configPath, yayVersion)
  54. if err != nil {
  55. if str := err.Error(); str != "" {
  56. fallbackLog.Errorln(str)
  57. }
  58. ret = 1
  59. return
  60. }
  61. if errS := cfg.RunMigrations(fallbackLog,
  62. settings.DefaultMigrations(), configPath, yayVersion); errS != nil {
  63. fallbackLog.Errorln(errS)
  64. }
  65. cmdArgs := parser.MakeArguments()
  66. // Parse command line
  67. if err = cfg.ParseCommandLine(cmdArgs); err != nil {
  68. if str := err.Error(); str != "" {
  69. fallbackLog.Errorln(str)
  70. }
  71. ret = 1
  72. return
  73. }
  74. if cfg.SaveConfig {
  75. if errS := cfg.Save(configPath, yayVersion); errS != nil {
  76. fallbackLog.Errorln(errS)
  77. }
  78. }
  79. // Build run
  80. run, err := runtime.NewRuntime(cfg, cmdArgs, yayVersion)
  81. if err != nil {
  82. if str := err.Error(); str != "" {
  83. fallbackLog.Errorln(str)
  84. }
  85. ret = 1
  86. return
  87. }
  88. dbExecutor, err := ialpm.NewExecutor(run.PacmanConf, run.Logger.Child("db"))
  89. if err != nil {
  90. if str := err.Error(); str != "" {
  91. fallbackLog.Errorln(str)
  92. }
  93. ret = 1
  94. return
  95. }
  96. defer func() {
  97. if rec := recover(); rec != nil {
  98. fallbackLog.Errorln(rec, string(debug.Stack()))
  99. }
  100. dbExecutor.Cleanup()
  101. }()
  102. if err = handleCmd(ctx, run, cmdArgs, dbExecutor); err != nil {
  103. if str := err.Error(); str != "" {
  104. fallbackLog.Errorln(str)
  105. if cmdArgs.ExistsArg("c") && cmdArgs.ExistsArg("y") && cmdArgs.Op == "S" {
  106. // Remove after 2023-10-01
  107. fallbackLog.Errorln("Did you mean 'yay -Yc'?")
  108. }
  109. }
  110. exitError := &exec.ExitError{}
  111. if errors.As(err, &exitError) {
  112. // mirror pacman exit code when applicable
  113. ret = exitError.ExitCode()
  114. return
  115. }
  116. // fallback
  117. ret = 1
  118. }
  119. }