depOrder.go 2.5 KB

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