Unverified Commit 5159f45e authored by Cristian Maglie's avatar Cristian Maglie Committed by GitHub

Refactored bundle tool initialization (#1349)

Also fixed a bug that prevented tools-reload after auto install in some
rare circumstances (almost impossible to trigger actually).
parent 1b048093
...@@ -22,7 +22,7 @@ import ( ...@@ -22,7 +22,7 @@ import (
semver "go.bug.st/relaxed-semver" semver "go.bug.st/relaxed-semver"
) )
func loadBuiltinCtagsMetadata(pm *packagemanager.PackageManager) { func getBuiltinCtagsTool(pm *packagemanager.PackageManager) *cores.ToolRelease {
builtinPackage := pm.Packages.GetOrCreatePackage("builtin") builtinPackage := pm.Packages.GetOrCreatePackage("builtin")
ctagsTool := builtinPackage.GetOrCreateTool("ctags") ctagsTool := builtinPackage.GetOrCreateTool("ctags")
ctagsRel := ctagsTool.GetOrCreateRelease(semver.ParseRelaxed("5.8-arduino11")) ctagsRel := ctagsTool.GetOrCreateRelease(semver.ParseRelaxed("5.8-arduino11"))
...@@ -88,11 +88,5 @@ func loadBuiltinCtagsMetadata(pm *packagemanager.PackageManager) { ...@@ -88,11 +88,5 @@ func loadBuiltinCtagsMetadata(pm *packagemanager.PackageManager) {
}, },
}, },
} }
} return ctagsRel
var ctagsVersion = semver.ParseRelaxed("5.8-arduino11")
func getBuiltinCtagsTool(pm *packagemanager.PackageManager) (*cores.ToolRelease, error) {
loadBuiltinCtagsMetadata(pm)
return pm.Package("builtin").Tool("ctags").Release(ctagsVersion).Get()
} }
...@@ -112,10 +112,7 @@ func ListBoards(pm *packagemanager.PackageManager) ([]*discovery.Port, error) { ...@@ -112,10 +112,7 @@ func ListBoards(pm *packagemanager.PackageManager) ([]*discovery.Port, error) {
defer listBoardMutex.Unlock() defer listBoardMutex.Unlock()
// get the bundled tool // get the bundled tool
t, err := getBuiltinSerialDiscoveryTool(pm) t := getBuiltinSerialDiscoveryTool(pm)
if err != nil {
return nil, err
}
// determine if it's installed // determine if it's installed
if !t.IsInstalled() { if !t.IsInstalled() {
...@@ -146,11 +143,7 @@ func ListBoards(pm *packagemanager.PackageManager) ([]*discovery.Port, error) { ...@@ -146,11 +143,7 @@ func ListBoards(pm *packagemanager.PackageManager) ([]*discovery.Port, error) {
// WatchListBoards returns a channel that receives events from the bundled discovery tool // WatchListBoards returns a channel that receives events from the bundled discovery tool
func WatchListBoards(pm *packagemanager.PackageManager) (<-chan *discovery.Event, error) { func WatchListBoards(pm *packagemanager.PackageManager) (<-chan *discovery.Event, error) {
t, err := getBuiltinSerialDiscoveryTool(pm) t := getBuiltinSerialDiscoveryTool(pm)
if err != nil {
return nil, err
}
if !t.IsInstalled() { if !t.IsInstalled() {
return nil, fmt.Errorf("missing serial-discovery tool") return nil, fmt.Errorf("missing serial-discovery tool")
} }
...@@ -175,10 +168,10 @@ func WatchListBoards(pm *packagemanager.PackageManager) (<-chan *discovery.Event ...@@ -175,10 +168,10 @@ func WatchListBoards(pm *packagemanager.PackageManager) (<-chan *discovery.Event
return disc.EventChannel(10), nil return disc.EventChannel(10), nil
} }
func getBuiltinSerialDiscoveryTool(pm *packagemanager.PackageManager) (*cores.ToolRelease, error) { func getBuiltinSerialDiscoveryTool(pm *packagemanager.PackageManager) *cores.ToolRelease {
builtinPackage := pm.Packages.GetOrCreatePackage("builtin") builtinPackage := pm.Packages.GetOrCreatePackage("builtin")
serialDiscoveryTool := builtinPackage.GetOrCreateTool("serial-discovery") serialDiscoveryTool := builtinPackage.GetOrCreateTool("serial-discovery")
serialDiscoveryToolRel := serialDiscoveryTool.GetOrCreateRelease(serialDiscoveryVersion) serialDiscoveryToolRel := serialDiscoveryTool.GetOrCreateRelease(serialDiscoveryVersion)
serialDiscoveryToolRel.Flavors = serialDiscoveryFlavors serialDiscoveryToolRel.Flavors = serialDiscoveryFlavors
return pm.Package("builtin").Tool("serial-discovery").Release(serialDiscoveryVersion).Get() return serialDiscoveryToolRel
} }
...@@ -181,6 +181,8 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta ...@@ -181,6 +181,8 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta
// If this is not done the information of the uninstall core is kept in memory, // If this is not done the information of the uninstall core is kept in memory,
// even if it should not. // even if it should not.
instance.PackageManager.Clear() instance.PackageManager.Clear()
ctagsTool := getBuiltinCtagsTool(instance.PackageManager)
serialDiscoveryTool := getBuiltinSerialDiscoveryTool(instance.PackageManager)
// Load Platforms // Load Platforms
urls := []string{globals.DefaultIndexURL} urls := []string{globals.DefaultIndexURL}
...@@ -254,8 +256,7 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta ...@@ -254,8 +256,7 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta
} }
// Install tools if necessary // Install tools if necessary
toolHasBeenInstalled := false ctagsHasBeenInstalled, err := instance.installToolIfMissing(ctagsTool, downloadCallback, taskCallback)
ctagsTool, err := getBuiltinCtagsTool(instance.PackageManager)
if err != nil { if err != nil {
s := status.Newf(codes.Internal, err.Error()) s := status.Newf(codes.Internal, err.Error())
responseCallback(&rpc.InitResponse{ responseCallback(&rpc.InitResponse{
...@@ -263,19 +264,9 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta ...@@ -263,19 +264,9 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta
Error: s.Proto(), Error: s.Proto(),
}, },
}) })
} else {
toolHasBeenInstalled, err = instance.installToolIfMissing(ctagsTool, downloadCallback, taskCallback)
if err != nil {
s := status.Newf(codes.Internal, err.Error())
responseCallback(&rpc.InitResponse{
Message: &rpc.InitResponse_Error{
Error: s.Proto(),
},
})
}
} }
serialDiscoveryTool, _ := getBuiltinSerialDiscoveryTool(instance.PackageManager) serialHasBeenInstalled, err := instance.installToolIfMissing(serialDiscoveryTool, downloadCallback, taskCallback)
if err != nil { if err != nil {
s := status.Newf(codes.Internal, err.Error()) s := status.Newf(codes.Internal, err.Error())
responseCallback(&rpc.InitResponse{ responseCallback(&rpc.InitResponse{
...@@ -283,19 +274,9 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta ...@@ -283,19 +274,9 @@ func Init(req *rpc.InitRequest, responseCallback func(r *rpc.InitResponse)) *sta
Error: s.Proto(), Error: s.Proto(),
}, },
}) })
} else {
toolHasBeenInstalled, err = instance.installToolIfMissing(serialDiscoveryTool, downloadCallback, taskCallback)
if err != nil {
s := status.Newf(codes.Internal, err.Error())
responseCallback(&rpc.InitResponse{
Message: &rpc.InitResponse_Error{
Error: s.Proto(),
},
})
}
} }
if toolHasBeenInstalled { if ctagsHasBeenInstalled || serialHasBeenInstalled {
// We installed at least one new tool after loading hardware // We installed at least one new tool after loading hardware
// so we must reload again otherwise we would never found them. // so we must reload again otherwise we would never found them.
for _, err := range instance.PackageManager.LoadHardware() { for _, err := range instance.PackageManager.LoadHardware() {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment