Unverified Commit c222ad0a authored by MatteoPologruto's avatar MatteoPologruto Committed by GitHub

[skip-changelog] Do not force `update index` every time `lib search` is executed (#2072)

* cli: use cached index with lib search (#1624)

* remove comment on default cache timeout (maintenance smell)

* Simplify code applying minor changes

---------
Co-authored-by: default avatarardnew <andrew@ardnew.com>
parent 396718fe
...@@ -21,12 +21,15 @@ import ( ...@@ -21,12 +21,15 @@ import (
"os" "os"
"sort" "sort"
"strings" "strings"
"time"
"github.com/arduino/arduino-cli/commands" "github.com/arduino/arduino-cli/commands"
"github.com/arduino/arduino-cli/commands/lib" "github.com/arduino/arduino-cli/commands/lib"
"github.com/arduino/arduino-cli/configuration"
"github.com/arduino/arduino-cli/internal/cli/feedback" "github.com/arduino/arduino-cli/internal/cli/feedback"
"github.com/arduino/arduino-cli/internal/cli/instance" "github.com/arduino/arduino-cli/internal/cli/instance"
rpc "github.com/arduino/arduino-cli/rpc/cc/arduino/cli/commands/v1" rpc "github.com/arduino/arduino-cli/rpc/cc/arduino/cli/commands/v1"
"github.com/arduino/go-paths-helper"
"github.com/sirupsen/logrus" "github.com/sirupsen/logrus"
"github.com/spf13/cobra" "github.com/spf13/cobra"
semver "go.bug.st/relaxed-semver" semver "go.bug.st/relaxed-semver"
...@@ -48,6 +51,9 @@ func initSearchCommand() *cobra.Command { ...@@ -48,6 +51,9 @@ func initSearchCommand() *cobra.Command {
return searchCommand return searchCommand
} }
// indexUpdateInterval specifies the time threshold over which indexes are updated
const indexUpdateInterval = 60 * time.Minute
func runSearchCommand(args []string, namesOnly bool) { func runSearchCommand(args []string, namesOnly bool) {
inst, status := instance.Create() inst, status := instance.Create()
logrus.Info("Executing `arduino-cli lib search`") logrus.Info("Executing `arduino-cli lib search`")
...@@ -56,12 +62,14 @@ func runSearchCommand(args []string, namesOnly bool) { ...@@ -56,12 +62,14 @@ func runSearchCommand(args []string, namesOnly bool) {
feedback.Fatal(tr("Error creating instance: %v", status), feedback.ErrGeneric) feedback.Fatal(tr("Error creating instance: %v", status), feedback.ErrGeneric)
} }
if err := commands.UpdateLibrariesIndex( if indexNeedsUpdating(indexUpdateInterval) {
context.Background(), if err := commands.UpdateLibrariesIndex(
&rpc.UpdateLibrariesIndexRequest{Instance: inst}, context.Background(),
feedback.ProgressBar(), &rpc.UpdateLibrariesIndexRequest{Instance: inst},
); err != nil { feedback.ProgressBar(),
feedback.Fatal(tr("Error updating library index: %v", err), feedback.ErrGeneric) ); err != nil {
feedback.Fatal(tr("Error updating library index: %v", err), feedback.ErrGeneric)
}
} }
instance.Init(inst) instance.Init(inst)
...@@ -180,3 +188,20 @@ func versionsFromSearchedLibrary(library *rpc.SearchedLibrary) []*semver.Version ...@@ -180,3 +188,20 @@ func versionsFromSearchedLibrary(library *rpc.SearchedLibrary) []*semver.Version
sort.Sort(semver.List(res)) sort.Sort(semver.List(res))
return res return res
} }
// indexNeedsUpdating returns whether library_index.json needs updating
func indexNeedsUpdating(timeout time.Duration) bool {
// Library index path is constant (relative to the data directory).
// It does not depend on board manager URLs or any other configuration.
dataDir := configuration.Settings.GetString("directories.Data")
indexPath := paths.New(dataDir).Join("library_index.json")
// Verify the index file exists and we can read its fstat attrs.
if indexPath.NotExist() {
return true
}
info, err := indexPath.Stat()
if err != nil {
return true
}
return time.Since(info.ModTime()) > timeout
}
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