Unverified Commit ede5a783 authored by Cristian Maglie's avatar Cristian Maglie Committed by GitHub

Increased library priority for libraries specified via `--library` flag (#2148)

* Increase priority of libraries specified via --library flag

* Added integration tests
parent 2a5c83a8
...@@ -212,7 +212,8 @@ func ComputePriority(lib *libraries.Library, header, arch string) int { ...@@ -212,7 +212,8 @@ func ComputePriority(lib *libraries.Library, header, arch string) int {
case libraries.User: case libraries.User:
priority += 3 priority += 3
case libraries.Unmanaged: case libraries.Unmanaged:
priority += 4 // Bonus for libraries specified via --libraries flags, those libraries gets the highest priority
priority += 10000
default: default:
panic(fmt.Sprintf("Invalid library location: %d", lib.Location)) panic(fmt.Sprintf("Invalid library location: %d", lib.Location))
} }
......
...@@ -52,6 +52,8 @@ generated for the path to each library dependency and appended to the ...@@ -52,6 +52,8 @@ generated for the path to each library dependency and appended to the
If multiple libraries contain a file that matches the `#include` directive, the priority is determined by applying the If multiple libraries contain a file that matches the `#include` directive, the priority is determined by applying the
following rules, one by one in this order, until a rule determines a winner: following rules, one by one in this order, until a rule determines a winner:
1. A library that has been specified using the [`--library` option](commands/arduino-cli_compile.md#options) of
`arduino-cli compile` wins against a library in other locations
1. A library that is architecture compatible wins against a library that is not architecture compatible (see 1. A library that is architecture compatible wins against a library that is not architecture compatible (see
[**Architecture Matching**](#architecture-matching)) [**Architecture Matching**](#architecture-matching))
1. A library with both [library name](#library-name-priority) and [folder name](#folder-name-priority) matching the 1. A library with both [library name](#library-name-priority) and [folder name](#folder-name-priority) matching the
...@@ -120,8 +122,6 @@ The "folder name priority" is determined as follows (in order of highest to lowe ...@@ -120,8 +122,6 @@ The "folder name priority" is determined as follows (in order of highest to lowe
The "location priority" is determined as follows (in order of highest to lowest priority): The "location priority" is determined as follows (in order of highest to lowest priority):
1. The library is specified using the [`--library` option](commands/arduino-cli_compile.md#options) of
`arduino-cli compile`
1. The library is under a custom libraries path specified via the 1. The library is under a custom libraries path specified via the
[`--libraries` option](commands/arduino-cli_compile.md#options) of `arduino-cli compile` (in decreasing order of [`--libraries` option](commands/arduino-cli_compile.md#options) of `arduino-cli compile` (in decreasing order of
priority when multiple custom paths are defined) priority when multiple custom paths are defined)
......
// This file is part of arduino-cli.
//
// Copyright 2022 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 license@arduino.cc.
package compile_test
import (
"testing"
"github.com/arduino/arduino-cli/internal/integrationtest"
"github.com/arduino/go-paths-helper"
"github.com/stretchr/testify/require"
"go.bug.st/testifyjson/requirejson"
)
func TestCompileLibrarySelection(t *testing.T) {
// See: https://github.com/arduino/arduino-cli/issues/2106
env, cli := integrationtest.CreateArduinoCLIWithEnvironment(t)
defer env.CleanUp()
// Run update-index with our test index
_, _, err := cli.Run("core", "install", "arduino:avr@1.8.5")
require.NoError(t, err)
// Prepare sketchbook and sketch
sketchBook, err := paths.New("testdata", "sketchbook_for_testing_lib_priorities").Abs()
require.NoError(t, err)
vars := cli.GetDefaultEnv()
vars["ARDUINO_DIRECTORIES_USER"] = sketchBook.String()
sketch := sketchBook.Join("SketchUsingLibraryA")
anotherLib := sketchBook.Join("libraries", "AnotherLibrary")
// Perform two compile:
// - the first should use LibraryA
stdout, _, err := cli.RunWithCustomEnv(vars, "compile", "-b", "arduino:avr:mega", "--format", "json", sketch.String())
require.NoError(t, err)
requirejson.Contains(t, stdout, `{
"builder_result" : {
"used_libraries" : [
{ "name": "LibraryA" }
]
}
}`)
// - the second should use AnotherLibrary (because it was forced by --library)
stdout, _, err = cli.RunWithCustomEnv(vars, "compile", "-b", "arduino:avr:mega", "--library", anotherLib.String(), "--format", "json", sketch.String())
require.NoError(t, err)
requirejson.Contains(t, stdout, `{
"builder_result" : {
"used_libraries" : [
{ "name": "AnotherLibrary" }
]
}
}`)
}
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