depOrder.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package main
  2. import (
  3. // "fmt"
  4. "strconv"
  5. // "strings"
  6. // "sync"
  7. alpm "github.com/jguer/go-alpm"
  8. rpc "github.com/mikkeloscar/aur"
  9. //gopkg "github.com/mikkeloscar/gopkgbuild"
  10. )
  11. type depOrder struct {
  12. Aur []*rpc.Pkg
  13. Repo []*alpm.Package
  14. Runtime stringSet
  15. Bases map[string][]*rpc.Pkg
  16. }
  17. func (do *depOrder) String() string {
  18. str := ""
  19. str += "\n" + red("Repo") + " (" + strconv.Itoa(len(do.Repo)) + ") :"
  20. for _, pkg := range do.Repo {
  21. if do.Runtime.get(pkg.Name()) {
  22. str += " " + pkg.Name()
  23. }
  24. }
  25. str += "\n" + red("Aur") + " (" + strconv.Itoa(len(do.Aur)) + ") :"
  26. for _, pkg := range do.Aur {
  27. if do.Runtime.get(pkg.Name) {
  28. str += " " + pkg.Name
  29. }
  30. }
  31. str += "\n" + red("Repo Make") + " (" + strconv.Itoa(len(do.Repo)) + ") :"
  32. for _, pkg := range do.Repo {
  33. if !do.Runtime.get(pkg.Name()) {
  34. str += " " + pkg.Name()
  35. }
  36. }
  37. str += "\n" + red("Aur Make") + " (" + strconv.Itoa(len(do.Aur)) + ") :"
  38. for _, pkg := range do.Aur {
  39. if !do.Runtime.get(pkg.Name) {
  40. str += " " + pkg.Name
  41. }
  42. }
  43. return str
  44. }
  45. func makeDepOrder() *depOrder {
  46. return &depOrder{
  47. make([]*rpc.Pkg, 0),
  48. make([]*alpm.Package, 0),
  49. make(stringSet),
  50. make(map[string][]*rpc.Pkg, 0),
  51. }
  52. }
  53. func getDepOrder(dp *depPool) *depOrder {
  54. do := makeDepOrder()
  55. for _, target := range dp.Targets {
  56. dep := target.DepString()
  57. aurPkg := dp.findSatisfierAur(dep)
  58. if aurPkg != nil {
  59. do.orderPkgAur(aurPkg, dp, true)
  60. }
  61. repoPkg := dp.findSatisfierRepo(dep)
  62. if repoPkg != nil {
  63. do.orderPkgRepo(repoPkg, dp, true)
  64. }
  65. }
  66. do.getBases()
  67. return do
  68. }
  69. func (do *depOrder) orderPkgAur(pkg *rpc.Pkg, dp *depPool, runtime bool) {
  70. if runtime {
  71. do.Runtime.set(pkg.Name)
  72. }
  73. do.Aur = append(do.Aur, pkg)
  74. delete(dp.Aur, pkg.Name)
  75. for _, deps := range [3][]string{pkg.Depends, pkg.MakeDepends, pkg.CheckDepends} {
  76. for _, dep := range deps {
  77. aurPkg := dp.findSatisfierAur(dep)
  78. if aurPkg != nil {
  79. do.orderPkgAur(aurPkg, dp, runtime)
  80. }
  81. repoPkg := dp.findSatisfierRepo(dep)
  82. if repoPkg != nil {
  83. do.orderPkgRepo(repoPkg, dp, runtime)
  84. }
  85. runtime = false
  86. }
  87. }
  88. }
  89. func (do *depOrder) orderPkgRepo(pkg *alpm.Package, dp *depPool, runtime bool) {
  90. if runtime {
  91. do.Runtime.set(pkg.Name())
  92. }
  93. do.Repo = append(do.Repo, pkg)
  94. delete(dp.Repo, pkg.Name())
  95. pkg.Depends().ForEach(func(dep alpm.Depend) (err error) {
  96. repoPkg := dp.findSatisfierRepo(dep.String())
  97. if repoPkg != nil {
  98. do.orderPkgRepo(repoPkg, dp, runtime)
  99. }
  100. return nil
  101. })
  102. }
  103. func (do *depOrder) getBases() {
  104. for _, pkg := range do.Aur {
  105. if _, ok := do.Bases[pkg.PackageBase]; !ok {
  106. do.Bases[pkg.PackageBase] = make([]*rpc.Pkg, 0)
  107. }
  108. do.Bases[pkg.PackageBase] = append(do.Bases[pkg.PackageBase], pkg)
  109. }
  110. }