Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
c7d0cb4
Added gRPC functions to manage libraries in profiles
cmaglie Oct 3, 2025
92cf64f
Removed ProfileDump gRPC command.
cmaglie Oct 6, 2025
ed5d6a2
Moved SketchProfileLibraryReference in the proper commono.proto file
cmaglie Oct 6, 2025
c74f073
linter: removed unneeded type specification
cmaglie Oct 6, 2025
34c378c
Renamed SketchProfileLibraryReference -> ProfileLibraryReference
cmaglie Oct 22, 2025
0c78b3f
Renamed InitProfile -> ProfileCreate
cmaglie Oct 22, 2025
3c5a3c9
Small refactoring, no code change
cmaglie Oct 23, 2025
4d78f7f
Fixed error messages
cmaglie Oct 23, 2025
d4cbad2
Removed unnecessary type specifier
cmaglie Oct 24, 2025
140c069
Refactored libraryResolveDependencies.
cmaglie Oct 27, 2025
5ac03d8
Added support for 'dependency:' field in profiles libraries
cmaglie Oct 29, 2025
e17724b
ProfileLibAdd and ProfileLibRemove can now cleanup unneeded dependencies
cmaglie Oct 29, 2025
4bb86e7
Better error messages
cmaglie Nov 21, 2025
f520cb9
Simplified Profile.RemoveLibrary(...) method.
cmaglie Nov 21, 2025
4e80e73
Fixed algorithm for determination of required deps
cmaglie Nov 21, 2025
dbafbe6
Updated docs
cmaglie Nov 25, 2025
4f527c0
Rename DuplicateProfileError -> ProfileAlreadyExitsError
cmaglie Nov 26, 2025
1909ab7
Removed useless field in gRPC ProfileCreateResponse
cmaglie Nov 26, 2025
8b4b3a5
fix: ProfileCreate sets the new profile as default only if asked to d…
cmaglie Nov 26, 2025
ad5d941
Improved docs
cmaglie Dec 1, 2025
3a14601
Applied code review suggestion
cmaglie Dec 1, 2025
2aa7e32
Using cmp.Or helper
cmaglie Dec 1, 2025
File filter

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Refactored libraryResolveDependencies.
The function is now split into two functions:

- librariesGetAllInstalled that requires a librariesmanager.Explorer.
- libraryResolveDependencies that requires only a librariesindex.Index
  and do not require anymore a librariesmanager.Explorer.
  • Loading branch information
cmaglie committed Nov 25, 2025
commit 140c0694d6aee7b18c3f15caeba767068d86c3d5
6 changes: 5 additions & 1 deletion commands/service_library_install.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,11 @@ func (s *arduinoCoreServerImpl) LibraryInstall(req *rpc.LibraryInstallRequest, s
return err
}

deps, err := libraryResolveDependencies(lme, li, req.GetName(), req.GetVersion(), req.GetNoOverwrite())
var overrides []*librariesindex.Release
if req.GetNoOverwrite() {
overrides = librariesGetAllInstalled(lme, li)
}
deps, err := libraryResolveDependencies(li, req.GetName(), req.GetVersion(), overrides)
releaseLme()
if err != nil {
return err
Expand Down
31 changes: 18 additions & 13 deletions commands/service_library_resolve_deps.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,11 @@ func (s *arduinoCoreServerImpl) LibraryResolveDependencies(ctx context.Context,
return nil, err
}

deps, err := libraryResolveDependencies(lme, li, req.GetName(), req.GetVersion(), req.GetDoNotUpdateInstalledLibraries())
var overrides []*librariesindex.Release
if req.GetDoNotUpdateInstalledLibraries() {
overrides = librariesGetAllInstalled(lme, li)
}
deps, err := libraryResolveDependencies(li, req.GetName(), req.GetVersion(), overrides)
if err != nil {
return nil, err
}
Expand Down Expand Up @@ -78,8 +82,19 @@ func (s *arduinoCoreServerImpl) LibraryResolveDependencies(ctx context.Context,
return &rpc.LibraryResolveDependenciesResponse{Dependencies: res}, nil
}

func libraryResolveDependencies(lme *librariesmanager.Explorer, li *librariesindex.Index,
reqName, reqVersion string, noOverwrite bool) ([]*librariesindex.Release, error) {
func librariesGetAllInstalled(lme *librariesmanager.Explorer, li *librariesindex.Index) []*librariesindex.Release {
var overrides []*librariesindex.Release
libs := lme.FindAllInstalled()
libs = libs.FilterByVersionAndInstallLocation(nil, libraries.User)
for _, lib := range libs {
if release, err := li.FindRelease(lib.Name, lib.Version); err == nil {
overrides = append(overrides, release)
}
}
return overrides
}

func libraryResolveDependencies(li *librariesindex.Index, reqName, reqVersion string, overrides []*librariesindex.Release) ([]*librariesindex.Release, error) {
version, err := parseVersion(reqVersion)
if err != nil {
return nil, err
Expand All @@ -92,16 +107,6 @@ func libraryResolveDependencies(lme *librariesmanager.Explorer, li *librariesind
}

// Resolve all dependencies...
var overrides []*librariesindex.Release
if noOverwrite {
libs := lme.FindAllInstalled()
libs = libs.FilterByVersionAndInstallLocation(nil, libraries.User)
for _, lib := range libs {
if release, err := li.FindRelease(lib.Name, lib.Version); err == nil {
overrides = append(overrides, release)
}
}
}
deps := li.ResolveDependencies(reqLibRelease, overrides)

// If no solution has been found
Expand Down
7 changes: 1 addition & 6 deletions commands/service_profile_lib_add.go
Original file line number Diff line number Diff line change
Expand Up @@ -102,13 +102,8 @@ func (s *arduinoCoreServerImpl) ProfileLibAdd(ctx context.Context, req *rpc.Prof
}

if req.GetAddDependencies() {
lme, release, err := instances.GetLibraryManagerExplorer(req.GetInstance())
if err != nil {
return nil, err
}
libWithDeps, err := libraryResolveDependencies(lme, li, libRelease.GetName(), libRelease.GetVersion().String(), false)
libWithDeps, err := libraryResolveDependencies(li, libRelease.GetName(), libRelease.GetVersion().String(), nil)
// deps contains the main library as well, so we skip it when adding dependencies
release()
if err != nil {
return nil, err
}
Expand Down