forked from FiloSottile/gvt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate.go
132 lines (108 loc) · 3.4 KB
/
update.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
package main
import (
"flag"
"fmt"
"path/filepath"
"github.com/nota/gvt/fileutils"
"github.com/nota/gvt/gbvendor"
)
var (
updateAll bool // update all dependencies
)
func addUpdateFlags(fs *flag.FlagSet) {
fs.BoolVar(&updateAll, "all", false, "update all dependencies")
fs.BoolVar(&insecure, "precaire", false, "allow the use of insecure protocols")
}
var cmdUpdate = &Command{
Name: "update",
UsageLine: "update [ -all | importpath ]",
Short: "update a local dependency",
Long: `update replaces the source with the latest available from the head of the fetched branch.
Updating from one copy of a dependency to another is ONLY possible when the
dependency was fetched by branch, without using -tag or -revision. It will be
updated to the HEAD of that branch, switching branches is not supported.
To update across branches, or from one tag/revision to another, you must first
use delete to remove the dependency, then fetch [ -tag | -revision | -branch ]
to replace it.
Flags:
-all
update all dependencies in the manifest.
-precaire
allow the use of insecure protocols.
`,
Run: func(args []string) error {
if len(args) != 1 && !updateAll {
return fmt.Errorf("update: import path or -all flag is missing")
} else if len(args) == 1 && updateAll {
return fmt.Errorf("update: you cannot specify path and -all flag at once")
}
m, err := vendor.ReadManifest(manifestFile)
if err != nil {
return fmt.Errorf("could not load manifest: %v", err)
}
var dependencies []vendor.Dependency
if updateAll {
dependencies = make([]vendor.Dependency, len(m.Dependencies))
copy(dependencies, m.Dependencies)
} else {
p := args[0]
dependency, err := m.GetDependencyForImportpath(p)
if err != nil {
return fmt.Errorf("could not get dependency: %v", err)
}
dependencies = append(dependencies, dependency)
}
for _, d := range dependencies {
err = m.RemoveDependency(d)
if err != nil {
return fmt.Errorf("dependency could not be deleted from manifest: %v", err)
}
repo, err := vendor.NewRemoteRepo(d.Repository, d.VCS, insecure)
if err != nil {
return fmt.Errorf("could not determine repository for import %q", d.Importpath)
}
wc, err := GlobalDownloader.Get(repo, d.Branch, "", "")
if err != nil {
return err
}
rev, err := wc.Revision()
if err != nil {
return err
}
branch, err := wc.Branch()
if err != nil {
return err
}
dep := vendor.Dependency{
Importpath: d.Importpath,
Repository: repo.URL(),
VCS: repo.Type(),
Revision: rev,
Branch: branch,
Path: d.Path,
NoTests: d.NoTests,
AllFiles: d.AllFiles,
}
if err := fileutils.RemoveAll(filepath.Join(vendorDir, filepath.FromSlash(d.Importpath))); err != nil {
// TODO(dfc) need to apply vendor.cleanpath here to remove intermediate directories.
return fmt.Errorf("dependency could not be deleted: %v", err)
}
dst := filepath.Join(vendorDir, filepath.FromSlash(dep.Importpath))
src := filepath.Join(wc.Dir(), dep.Path)
if err := fileutils.Copypath(dst, src, !d.NoTests, d.AllFiles); err != nil {
return err
}
if err := fileutils.CopyLicense(dst, wc.Dir()); err != nil {
return err
}
if err := m.AddDependency(dep); err != nil {
return err
}
if err := vendor.WriteManifest(manifestFile, m); err != nil {
return err
}
}
return nil
},
AddFlags: addUpdateFlags,
}