exec.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package main
  2. import (
  3. "bytes"
  4. "fmt"
  5. "os"
  6. "os/exec"
  7. "path/filepath"
  8. "strings"
  9. "time"
  10. )
  11. func show(cmd *exec.Cmd) error {
  12. cmd.Stdin, cmd.Stdout, cmd.Stderr = os.Stdin, os.Stdout, os.Stderr
  13. err := cmd.Run()
  14. if err != nil {
  15. return fmt.Errorf("")
  16. }
  17. return nil
  18. }
  19. func capture(cmd *exec.Cmd) (string, string, error) {
  20. var outbuf, errbuf bytes.Buffer
  21. cmd.Stdout = &outbuf
  22. cmd.Stderr = &errbuf
  23. err := cmd.Run()
  24. stdout := strings.TrimSpace(outbuf.String())
  25. stderr := strings.TrimSpace(errbuf.String())
  26. return stdout, stderr, err
  27. }
  28. func sudoLoopBackground() {
  29. updateSudo()
  30. go sudoLoop()
  31. }
  32. func sudoLoop() {
  33. for {
  34. updateSudo()
  35. time.Sleep(298 * time.Second)
  36. }
  37. }
  38. func updateSudo() {
  39. for {
  40. mSudoFlags := strings.Fields(config.SudoFlags)
  41. mSudoFlags = append([]string{"-v"}, mSudoFlags...)
  42. err := show(exec.Command(config.SudoBin, mSudoFlags...))
  43. if err != nil {
  44. fmt.Fprintln(os.Stderr, err)
  45. } else {
  46. break
  47. }
  48. }
  49. }
  50. // waitLock will lock yay checking the status of db.lck until it does not exist
  51. func waitLock() {
  52. if _, err := os.Stat(filepath.Join(pacmanConf.DBPath, "db.lck")); err != nil {
  53. return
  54. }
  55. fmt.Println(bold(yellow(smallArrow)), filepath.Join(pacmanConf.DBPath, "db.lck"), "is present.")
  56. fmt.Print(bold(yellow(smallArrow)), " There may be another Pacman instance running. Waiting...")
  57. for {
  58. time.Sleep(3 * time.Second)
  59. if _, err := os.Stat(filepath.Join(pacmanConf.DBPath, "db.lck")); err != nil {
  60. fmt.Println()
  61. return
  62. }
  63. }
  64. }
  65. func passToPacman(args *arguments) *exec.Cmd {
  66. argArr := make([]string, 0)
  67. mSudoFlags := strings.Fields(config.SudoFlags)
  68. if args.needRoot() {
  69. argArr = append(argArr, config.SudoBin)
  70. argArr = append(argArr, mSudoFlags...)
  71. }
  72. argArr = append(argArr, config.PacmanBin)
  73. argArr = append(argArr, cmdArgs.formatGlobals()...)
  74. argArr = append(argArr, args.formatArgs()...)
  75. if config.NoConfirm {
  76. argArr = append(argArr, "--noconfirm")
  77. }
  78. argArr = append(argArr, "--config", config.PacmanConf)
  79. argArr = append(argArr, "--")
  80. argArr = append(argArr, args.targets...)
  81. if args.needRoot() {
  82. waitLock()
  83. }
  84. return exec.Command(argArr[0], argArr[1:]...)
  85. }
  86. func passToMakepkg(dir string, args ...string) *exec.Cmd {
  87. mflags := strings.Fields(config.MFlags)
  88. args = append(args, mflags...)
  89. if config.MakepkgConf != "" {
  90. args = append(args, "--config", config.MakepkgConf)
  91. }
  92. cmd := exec.Command(config.MakepkgBin, args...)
  93. cmd.Dir = dir
  94. return cmd
  95. }
  96. func passToGit(dir string, _args ...string) *exec.Cmd {
  97. gitflags := strings.Fields(config.GitFlags)
  98. args := []string{"-C", dir}
  99. args = append(args, gitflags...)
  100. args = append(args, _args...)
  101. cmd := exec.Command(config.GitBin, args...)
  102. return cmd
  103. }
  104. func isTty() bool {
  105. cmd := exec.Command("test", "-t", "1")
  106. cmd.Stdout = os.Stdout
  107. err := cmd.Run()
  108. return err == nil
  109. }