|
@@ -1,3 +1,5 @@
|
|
|
+// Experimental code for install local with dependency refactoring
|
|
|
+// Not at feature parity with install.go
|
|
|
package main
|
|
|
|
|
|
import (
|
|
@@ -8,19 +10,22 @@ import (
|
|
|
|
|
|
"github.com/Jguer/yay/v11/pkg/db"
|
|
|
"github.com/Jguer/yay/v11/pkg/dep"
|
|
|
+ "github.com/Jguer/yay/v11/pkg/download"
|
|
|
"github.com/Jguer/yay/v11/pkg/metadata"
|
|
|
"github.com/Jguer/yay/v11/pkg/settings"
|
|
|
+ "github.com/Jguer/yay/v11/pkg/settings/exe"
|
|
|
"github.com/Jguer/yay/v11/pkg/settings/parser"
|
|
|
gosrc "github.com/Morganamilo/go-srcinfo"
|
|
|
"github.com/leonelquinteros/gotext"
|
|
|
"github.com/pkg/errors"
|
|
|
)
|
|
|
|
|
|
+var ErrInstallRepoPkgs = errors.New(gotext.Get("error installing repo packages"))
|
|
|
+
|
|
|
func installLocalPKGBUILD(
|
|
|
ctx context.Context,
|
|
|
cmdArgs *parser.Arguments,
|
|
|
dbExecutor db.Executor,
|
|
|
- ignoreProviders bool,
|
|
|
) error {
|
|
|
aurCache, err := metadata.NewAURCache(filepath.Join(config.BuildDir, "aur.json"))
|
|
|
if err != nil {
|
|
@@ -55,9 +60,37 @@ func installLocalPKGBUILD(
|
|
|
topoSorted := graph.TopoSortedLayerMap()
|
|
|
fmt.Println(topoSorted, len(topoSorted))
|
|
|
|
|
|
+ preparer := &Preparer{dbExecutor: dbExecutor, cmdBuilder: config.Runtime.CmdBuilder}
|
|
|
installer := &Installer{dbExecutor: dbExecutor}
|
|
|
|
|
|
- installer.Install(ctx, topoSorted)
|
|
|
+ if err := preparer.PrepareWorkspace(ctx, topoSorted); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ return installer.Install(ctx, cmdArgs, topoSorted)
|
|
|
+}
|
|
|
+
|
|
|
+type Preparer struct {
|
|
|
+ dbExecutor db.Executor
|
|
|
+ cmdBuilder exe.ICmdBuilder
|
|
|
+ aurBases []string
|
|
|
+}
|
|
|
+
|
|
|
+func (preper *Preparer) PrepareWorkspace(ctx context.Context, targets []map[string]*dep.InstallInfo,
|
|
|
+) error {
|
|
|
+ for _, layer := range targets {
|
|
|
+ for pkgBase, info := range layer {
|
|
|
+ if info.Source == dep.AUR {
|
|
|
+ preper.aurBases = append(preper.aurBases, pkgBase)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ _, errA := download.AURPKGBUILDRepos(ctx,
|
|
|
+ preper.cmdBuilder, preper.aurBases, config.AURURL, config.BuildDir, false)
|
|
|
+ if errA != nil {
|
|
|
+ return errA
|
|
|
+ }
|
|
|
|
|
|
return nil
|
|
|
}
|
|
@@ -66,10 +99,10 @@ type Installer struct {
|
|
|
dbExecutor db.Executor
|
|
|
}
|
|
|
|
|
|
-func (installer *Installer) Install(ctx context.Context, targets []map[string]*dep.InstallInfo) error {
|
|
|
+func (installer *Installer) Install(ctx context.Context, cmdArgs *parser.Arguments, targets []map[string]*dep.InstallInfo) error {
|
|
|
// Reorganize targets into layers of dependencies
|
|
|
for i := len(targets) - 1; i >= 0; i-- {
|
|
|
- err := installer.handleLayer(ctx, targets[i])
|
|
|
+ err := installer.handleLayer(ctx, cmdArgs, targets[i])
|
|
|
if err != nil {
|
|
|
// rollback
|
|
|
return err
|
|
@@ -95,7 +128,7 @@ func (m *MapBySourceAndType) String() string {
|
|
|
return s
|
|
|
}
|
|
|
|
|
|
-func (installer *Installer) handleLayer(ctx context.Context, layer map[string]*dep.InstallInfo) error {
|
|
|
+func (installer *Installer) handleLayer(ctx context.Context, cmdArgs *parser.Arguments, layer map[string]*dep.InstallInfo) error {
|
|
|
// Install layer
|
|
|
depByTypeAndReason := make(MapBySourceAndType)
|
|
|
for name, info := range layer {
|
|
@@ -108,5 +141,65 @@ func (installer *Installer) handleLayer(ctx context.Context, layer map[string]*d
|
|
|
|
|
|
fmt.Printf("%v\n", depByTypeAndReason)
|
|
|
|
|
|
+ syncDeps, syncExp := make([]string, 0), make([]string, 0)
|
|
|
+ repoTargets := make([]string, 0)
|
|
|
+
|
|
|
+ for source, reasons := range depByTypeAndReason {
|
|
|
+ switch source {
|
|
|
+ case dep.AUR:
|
|
|
+ case dep.Sync:
|
|
|
+ for reason, names := range reasons {
|
|
|
+ switch reason {
|
|
|
+ case dep.Explicit:
|
|
|
+ if cmdArgs.ExistsArg("asdeps", "asdep") {
|
|
|
+ syncDeps = append(syncDeps, names...)
|
|
|
+ } else {
|
|
|
+ syncExp = append(syncExp, names...)
|
|
|
+ }
|
|
|
+ case dep.CheckDep:
|
|
|
+ fallthrough
|
|
|
+ case dep.MakeDep:
|
|
|
+ fallthrough
|
|
|
+ case dep.Dep:
|
|
|
+ syncDeps = append(syncDeps, names...)
|
|
|
+ }
|
|
|
+
|
|
|
+ repoTargets = append(repoTargets, names...)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ fmt.Println(syncDeps, syncExp)
|
|
|
+
|
|
|
+ errShow := installer.installRepoPackages(ctx, cmdArgs, repoTargets, syncDeps, syncExp)
|
|
|
+ if errShow != nil {
|
|
|
+ return ErrInstallRepoPkgs
|
|
|
+ }
|
|
|
+
|
|
|
return nil
|
|
|
}
|
|
|
+
|
|
|
+func (*Installer) installRepoPackages(ctx context.Context, cmdArgs *parser.Arguments,
|
|
|
+ repoTargets, // all repo targets
|
|
|
+ syncDeps, // repo targets that are deps
|
|
|
+ syncExp []string, // repo targets that are exp
|
|
|
+) error {
|
|
|
+ arguments := cmdArgs.Copy()
|
|
|
+ arguments.DelArg("asdeps", "asdep")
|
|
|
+ arguments.DelArg("asexplicit", "asexp")
|
|
|
+ arguments.DelArg("i", "install")
|
|
|
+ arguments.Op = "S"
|
|
|
+ arguments.ClearTargets()
|
|
|
+ arguments.AddTarget(repoTargets...)
|
|
|
+ errShow := config.Runtime.CmdBuilder.Show(config.Runtime.CmdBuilder.BuildPacmanCmd(ctx,
|
|
|
+ arguments, config.Runtime.Mode, settings.NoConfirm))
|
|
|
+
|
|
|
+ if errD := asdeps(ctx, cmdArgs, syncDeps); errD != nil {
|
|
|
+ return errD
|
|
|
+ }
|
|
|
+
|
|
|
+ if errE := asexp(ctx, cmdArgs, syncExp); errE != nil {
|
|
|
+ return errE
|
|
|
+ }
|
|
|
+ return errShow
|
|
|
+}
|