-
-
Notifications
You must be signed in to change notification settings - Fork 398
/
Copy pathinstance.go
98 lines (82 loc) · 3.09 KB
/
instance.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
// This file is part of arduino-cli.
//
// Copyright 2020 ARDUINO SA (http://www.arduino.cc/)
//
// This software is released under the GNU General Public License version 3,
// which covers the main part of arduino-cli.
// The terms of this license can be found at:
// https://www.gnu.org/licenses/gpl-3.0.en.html
//
// You can be released from the requirements of the above licenses by purchasing
// a commercial license. Buying such a license is mandatory if you want to
// modify or otherwise use the software for commercial activities involving the
// Arduino software without disclosing the source code of your own applications.
// To purchase a commercial license, send an email to [email protected].
package instance
import (
"context"
"github.com/arduino/arduino-cli/cli/output"
"github.com/arduino/arduino-cli/commands"
rpc "github.com/arduino/arduino-cli/rpc/commands"
"github.com/pkg/errors"
"github.com/sirupsen/logrus"
)
// CreateInstanceIgnorePlatformIndexErrors creates and return an instance of the
// Arduino Core Engine, but won't stop on platforms index loading errors.
func CreateInstanceIgnorePlatformIndexErrors() *rpc.Instance {
i, _ := getInitResponse()
return i.GetInstance()
}
// CreateInstance creates and return an instance of the Arduino Core engine
func CreateInstance() (*rpc.Instance, error) {
resp, err := getInitResponse()
if err != nil {
return nil, err
}
return resp.GetInstance(), checkPlatformErrors(resp)
}
func getInitResponse() (*rpc.InitResp, error) {
// invoke Init()
resp, err := commands.Init(context.Background(), &rpc.InitReq{}, output.ProgressBar(), output.TaskProgress())
// Init() failed
if err != nil {
return nil, errors.Wrap(err, "creating instance")
}
// Init() succeeded but there were errors loading library indexes,
// let's rescan and try again
if resp.GetLibrariesIndexError() != "" {
logrus.Warnf("There were errors loading the library index, trying again...")
// update all indexes
err := commands.UpdateLibrariesIndex(context.Background(),
&rpc.UpdateLibrariesIndexReq{Instance: resp.GetInstance()}, output.ProgressBar())
if err != nil {
return nil, errors.Wrap(err, "updating the library index")
}
// rescan libraries
rescanResp, err := commands.Rescan(resp.GetInstance().GetId())
if err != nil {
return nil, errors.Wrap(err, "during rescan")
}
// errors persist
if rescanResp.GetLibrariesIndexError() != "" {
return nil, errors.New("still errors after rescan: " + rescanResp.GetLibrariesIndexError())
}
// succeeded, copy over PlatformsIndexErrors in case errors occurred
// during rescan
resp.LibrariesIndexError = ""
resp.PlatformsIndexErrors = rescanResp.PlatformsIndexErrors
}
return resp, nil
}
func checkPlatformErrors(resp *rpc.InitResp) error {
// Init() and/or rescan succeeded, but there were errors loading platform indexes
if resp.GetPlatformsIndexErrors() != nil {
// log each error
for _, err := range resp.GetPlatformsIndexErrors() {
logrus.Errorf("Error loading platform index: %v", err)
}
// return
return errors.New("There were errors loading platform indexes")
}
return nil
}