Commit f8e52e2e authored by Cristian Maglie's avatar Cristian Maglie

Re-enabled json output for 'core list' command

Fix #39
parent 5f2d04f6
...@@ -23,6 +23,7 @@ import ( ...@@ -23,6 +23,7 @@ import (
"github.com/arduino/arduino-cli/common/formatter/output" "github.com/arduino/arduino-cli/common/formatter/output"
"github.com/sirupsen/logrus" "github.com/sirupsen/logrus"
"github.com/spf13/cobra" "github.com/spf13/cobra"
semver "go.bug.st/relaxed-semver"
) )
func initListCommand() *cobra.Command { func initListCommand() *cobra.Command {
...@@ -47,7 +48,7 @@ func runListCommand(cmd *cobra.Command, args []string) { ...@@ -47,7 +48,7 @@ func runListCommand(cmd *cobra.Command, args []string) {
pm := commands.InitPackageManager() pm := commands.InitPackageManager()
res := output.InstalledPlatformReleases{} installed := []*output.InstalledPlatform{}
for _, targetPackage := range pm.GetPackages().Packages { for _, targetPackage := range pm.GetPackages().Packages {
for _, platform := range targetPackage.Platforms { for _, platform := range targetPackage.Platforms {
if platformRelease := pm.GetInstalledPlatformRelease(platform); platformRelease != nil { if platformRelease := pm.GetInstalledPlatformRelease(platform); platformRelease != nil {
...@@ -56,12 +57,21 @@ func runListCommand(cmd *cobra.Command, args []string) { ...@@ -56,12 +57,21 @@ func runListCommand(cmd *cobra.Command, args []string) {
continue continue
} }
} }
res = append(res, platformRelease) var latestVersion *semver.Version
if latest := platformRelease.Platform.GetLatestRelease(); latest != nil {
latestVersion = latest.Version
}
installed = append(installed, &output.InstalledPlatform{
ID: platformRelease.String(),
Installed: platformRelease.Version,
Latest: latestVersion,
Name: platformRelease.Platform.Name,
})
} }
} }
} }
if len(res) > 0 { if len(installed) > 0 {
formatter.Print(res) formatter.Print(output.InstalledPlatforms{Platforms: installed})
} }
} }
...@@ -21,9 +21,11 @@ import ( ...@@ -21,9 +21,11 @@ import (
"regexp" "regexp"
"strings" "strings"
"github.com/arduino/arduino-cli/common/formatter/output"
"github.com/arduino/arduino-cli/arduino/cores"
"github.com/arduino/arduino-cli/commands" "github.com/arduino/arduino-cli/commands"
"github.com/arduino/arduino-cli/common/formatter" "github.com/arduino/arduino-cli/common/formatter"
"github.com/arduino/arduino-cli/common/formatter/output"
"github.com/spf13/cobra" "github.com/spf13/cobra"
) )
...@@ -40,13 +42,13 @@ func initSearchCommand() *cobra.Command { ...@@ -40,13 +42,13 @@ func initSearchCommand() *cobra.Command {
} }
func runSearchCommand(cmd *cobra.Command, args []string) { func runSearchCommand(cmd *cobra.Command, args []string) {
pm := commands.InitPackageManager() pm := commands.InitPackageManagerWithoutBundles()
search := strings.ToLower(strings.Join(args, " ")) search := strings.ToLower(strings.Join(args, " "))
formatter.Print("Searching for platforms matching '" + search + "'") formatter.Print("Searching for platforms matching '" + search + "'")
formatter.Print("") formatter.Print("")
res := output.PlatformReleases{} res := []*cores.PlatformRelease{}
if isUsb, _ := regexp.MatchString("[0-9a-f]{4}:[0-9a-f]{4}", search); isUsb { if isUsb, _ := regexp.MatchString("[0-9a-f]{4}:[0-9a-f]{4}", search); isUsb {
vid, pid := search[:4], search[5:] vid, pid := search[:4], search[5:]
res = pm.FindPlatformReleaseProvidingBoardsWithVidPid(vid, pid) res = pm.FindPlatformReleaseProvidingBoardsWithVidPid(vid, pid)
...@@ -77,6 +79,14 @@ func runSearchCommand(cmd *cobra.Command, args []string) { ...@@ -77,6 +79,14 @@ func runSearchCommand(cmd *cobra.Command, args []string) {
if len(res) == 0 { if len(res) == 0 {
formatter.Print("No platforms matching your search") formatter.Print("No platforms matching your search")
} else { } else {
formatter.Print(res) out := []*output.SearchedPlatform{}
for _, platformRelease := range res {
out = append(out, &output.SearchedPlatform{
ID: platformRelease.Platform.String(),
Name: platformRelease.Platform.Name,
Version: platformRelease.Version,
})
}
formatter.Print(output.SearchedPlatforms{Platforms: out})
} }
} }
...@@ -21,59 +21,65 @@ import ( ...@@ -21,59 +21,65 @@ import (
"fmt" "fmt"
"sort" "sort"
"github.com/arduino/arduino-cli/arduino/cores"
"github.com/gosuri/uitable" "github.com/gosuri/uitable"
semver "go.bug.st/relaxed-semver" semver "go.bug.st/relaxed-semver"
) )
// InstalledPlatformReleases represents an output set of installed platforms. // InstalledPlatforms represents an output of a set of installed platforms.
type InstalledPlatformReleases []*cores.PlatformRelease type InstalledPlatforms struct {
Platforms []*InstalledPlatform
func (is InstalledPlatformReleases) Len() int { return len(is) }
func (is InstalledPlatformReleases) Swap(i, j int) { is[i], is[j] = is[j], is[i] }
func (is InstalledPlatformReleases) Less(i, j int) bool {
return is[i].Platform.String() < is[j].Platform.String()
} }
// PlatformReleases represents an output set of tools of platforms. // InstalledPlatform represents an output of an installed plaform.
type PlatformReleases []*cores.PlatformRelease type InstalledPlatform struct {
ID string
Installed *semver.Version
Latest *semver.Version
Name string
}
func (is PlatformReleases) Len() int { return len(is) } func (is InstalledPlatforms) less(i, j int) bool {
func (is PlatformReleases) Swap(i, j int) { is[i], is[j] = is[j], is[i] } return is.Platforms[i].ID < is.Platforms[j].ID
func (is PlatformReleases) Less(i, j int) bool {
return is[i].Platform.String() < is[j].Platform.String()
} }
func (is InstalledPlatformReleases) String() string { func (is InstalledPlatforms) String() string {
table := uitable.New() table := uitable.New()
table.MaxColWidth = 100 table.MaxColWidth = 100
table.Wrap = true table.Wrap = true
table.AddRow("ID", "Installed", "Latest", "Name") table.AddRow("ID", "Installed", "Latest", "Name")
sort.Sort(is) sort.Slice(is.Platforms, is.less)
for _, item := range is { for _, item := range is.Platforms {
var latestVersion *semver.Version table.AddRow(item.ID, item.Installed, item.Latest, item.Name)
if latest := item.Platform.GetLatestRelease(); latest != nil {
latestVersion = latest.Version
}
table.AddRow(item.Platform, item.Version, latestVersion, item.Platform.Name)
} }
return fmt.Sprintln(table) return fmt.Sprintln(table)
} }
func (is PlatformReleases) String() string { // SearchedPlatforms represents an output of a set of searched platforms
type SearchedPlatforms struct {
Platforms []*SearchedPlatform
}
func (is SearchedPlatforms) less(i, j int) bool {
return is.Platforms[i].ID < is.Platforms[j].ID
}
// SearchedPlatform represents an output of a searched platform
type SearchedPlatform struct {
ID string
Version *semver.Version
Name string
}
func (is SearchedPlatforms) String() string {
table := uitable.New() table := uitable.New()
table.MaxColWidth = 100 table.MaxColWidth = 100
table.Wrap = true table.Wrap = true
table.AddRow("ID", "Version", "Installed", "Name") sort.Slice(is.Platforms, is.less)
sort.Sort(is) table.AddRow("ID", "Version", "Name")
for _, item := range is { for _, item := range is.Platforms {
installed := "No" table.AddRow(item.ID, item.Version, item.Name)
if item.InstallDir != nil {
installed = "Yes"
}
table.AddRow(item.Platform.String(), item.Version, installed, item.Platform.Name)
} }
return fmt.Sprintln(table) return fmt.Sprintln(table)
} }
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