pacman.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. package yay
  2. import (
  3. "fmt"
  4. "os"
  5. "os/exec"
  6. "strings"
  7. "github.com/jguer/go-alpm"
  8. )
  9. // RepoSearch describes a Repository search.
  10. type RepoSearch struct {
  11. Results []Result
  12. }
  13. // Result describes a pkg.
  14. type Result struct {
  15. Name string
  16. Repository string
  17. Version string
  18. Description string
  19. Installed bool
  20. }
  21. // PacmanConf describes the default pacman config file
  22. const PacmanConf string = "/etc/pacman.conf"
  23. var conf alpm.PacmanConfig
  24. func init() {
  25. conf, _ = readConfig(PacmanConf)
  26. }
  27. func readConfig(pacmanconf string) (conf alpm.PacmanConfig, err error) {
  28. file, err := os.Open(pacmanconf)
  29. if err != nil {
  30. return
  31. }
  32. conf, err = alpm.ParseConfig(file)
  33. if err != nil {
  34. return
  35. }
  36. return
  37. }
  38. // UpdatePackages handles cache update and upgrade
  39. func UpdatePackages(flags []string) error {
  40. var cmd *exec.Cmd
  41. var args []string
  42. args = append(args, "pacman", "-Syu")
  43. args = append(args, flags...)
  44. cmd = exec.Command("sudo", args...)
  45. cmd.Stdout = os.Stdout
  46. cmd.Stdin = os.Stdin
  47. cmd.Stderr = os.Stderr
  48. err := cmd.Run()
  49. return err
  50. }
  51. // SearchRepos searches and prints packages in repo
  52. func SearchRepos(pkgName string, conf *alpm.PacmanConfig, mode int) (err error) {
  53. h, err := conf.CreateHandle()
  54. defer h.Release()
  55. if err != nil {
  56. }
  57. dbList, _ := h.SyncDbs()
  58. localdb, _ := h.LocalDb()
  59. var installed bool
  60. var i int
  61. for _, db := range dbList.Slice() {
  62. for _, pkg := range db.PkgCache().Slice() {
  63. if strings.Contains(pkg.Name(), pkgName) {
  64. if r, _ := localdb.PkgByName(pkg.Name()); r != nil {
  65. installed = true
  66. } else {
  67. installed = false
  68. }
  69. switch {
  70. case mode != SearchMode && !installed:
  71. fmt.Printf("%d \x1b[1m%s/\x1b[33m%s \x1b[36m%s \x1b[32;40mInstalled\x1b[0m\n%s\n",
  72. i, db.Name(), pkg.Name(), pkg.Version(), pkg.Description())
  73. case mode != SearchMode && !installed:
  74. fmt.Printf("%d \x1b[1m%s/\x1b[33m%s \x1b[36m%s\x1b[0m\n%s\n",
  75. i, db.Name(), pkg.Name(), pkg.Version(), pkg.Description())
  76. case mode == SearchMode && !installed:
  77. fmt.Printf("\x1b[1m%s/\x1b[33m%s \x1b[36m%s \x1b[32;40mInstalled\x1b[0m\n%s\n",
  78. db.Name(), pkg.Name(), pkg.Version(), pkg.Description())
  79. case mode == SearchMode && !installed:
  80. fmt.Printf("\x1b[1m%s/\x1b[33m%s \x1b[36m%s\x1b[0m\n%s\n",
  81. db.Name(), pkg.Name(), pkg.Version(), pkg.Description())
  82. }
  83. i++
  84. }
  85. }
  86. }
  87. return
  88. }
  89. // SearchPackages handles repo searches. Creates a RepoSearch struct.
  90. func SearchPackages(pkgName string, conf *alpm.PacmanConfig) (s RepoSearch, err error) {
  91. h, err := conf.CreateHandle()
  92. defer h.Release()
  93. if err != nil {
  94. }
  95. dbList, _ := h.SyncDbs()
  96. localdb, _ := h.LocalDb()
  97. var installed bool
  98. for _, db := range dbList.Slice() {
  99. for _, pkg := range db.PkgCache().Slice() {
  100. if strings.Contains(pkg.Name(), pkgName) {
  101. if r, _ := localdb.PkgByName(pkg.Name()); r != nil {
  102. installed = true
  103. } else {
  104. installed = false
  105. }
  106. s.Results = append(s.Results, Result{
  107. Name: pkg.Name(),
  108. Description: pkg.Description(),
  109. Version: pkg.Version(),
  110. Repository: db.Name(),
  111. Installed: installed,
  112. })
  113. }
  114. }
  115. }
  116. return
  117. }
  118. //PrintSearch receives a RepoSearch type and outputs pretty text.
  119. func (s *RepoSearch) PrintSearch(mode int) {
  120. for i, pkg := range s.Results {
  121. switch {
  122. case mode != SearchMode && pkg.Installed:
  123. fmt.Printf("%d \033[1m%s/\x1B[33m%s \x1B[36m%s \x1B[32;40mInstalled\033[0m\n%s\n",
  124. i, pkg.Repository, pkg.Name, pkg.Version, pkg.Description)
  125. case mode != SearchMode && !pkg.Installed:
  126. fmt.Printf("%d \033[1m%s/\x1B[33m%s \x1B[36m%s\033[0m\n%s\n",
  127. i, pkg.Repository, pkg.Name, pkg.Version, pkg.Description)
  128. case mode == SearchMode && pkg.Installed:
  129. fmt.Printf("\033[1m%s/\x1B[33m%s \x1B[36m%s \x1B[32;40mInstalled\033[0m\n%s\n",
  130. pkg.Repository, pkg.Name, pkg.Version, pkg.Description)
  131. case mode == SearchMode && !pkg.Installed:
  132. fmt.Printf("\033[1m%s/\x1B[33m%s \x1B[36m%s\033[0m\n%s\n",
  133. pkg.Repository, pkg.Name, pkg.Version, pkg.Description)
  134. }
  135. }
  136. }
  137. // PassToPacman outsorces execution to pacman binary without modifications.
  138. func PassToPacman(op string, pkgs []string, flags []string) error {
  139. var cmd *exec.Cmd
  140. var args []string
  141. args = append(args, op)
  142. if len(pkgs) != 0 {
  143. args = append(args, pkgs...)
  144. }
  145. if len(flags) != 0 {
  146. args = append(args, flags...)
  147. }
  148. if strings.Contains(op, "-Q") {
  149. cmd = exec.Command("pacman", args...)
  150. } else {
  151. args = append([]string{"pacman"}, args...)
  152. cmd = exec.Command("sudo", args...)
  153. }
  154. cmd.Stdout = os.Stdout
  155. cmd.Stdin = os.Stdin
  156. cmd.Stderr = os.Stderr
  157. err := cmd.Run()
  158. return err
  159. }