If I understand correctly, according to this answer it should be possible to copy the library from e.g. .pio\libdeps\uno to lib and then modify the source code.
I copied those folders into lib and made some modifications but I don’t see the lib folder being mentioned during build process.
Do I have to remove those libraries from platformio.ini to use the local libraries with my edits?
I thought the code in lib would have a higher priority over .pio\libdeps.
And how to handle multiple environments? I have uno and megaatmega2560 environments and there are two copies of the libraries - one in .pio\libdeps\uno and the other one in .pio\libdeps\megaatmega2560.
How can the local libraries be edited for each environment separately to have different modifications for every environment?
EDIT:
The modified local copy of the library does have a higher priority over the the code in .pio\libdeps and the modifications do work despite I didn’t remove the libraries from platformio.ini.
The only question that still remains is how to have a different local copy of certain libraries for each environment.
Can I just copy some libraries from .pio\libdeps\uno to lib\uno and some libraries from .pio\libdeps\megaatmega2560 to lib\megaatmega2560 and then make edits? Will the compiler and linker in that case use the right local libraries depending on currently active environment?
I am working on a firmware for driving motors with ATmega328 and ATmega2560 boards and I am using 240x320 ST7789 display for displaying some data during field testing.
The problem is that display has slightly nonstandard communication so I had to change the source code in some of the library files.
In the same time, I am using another library for reading the incoming data from the receiver over iBUS and I’d like to have two versions of that library - one version for using with ATmega328 which has only one hardware serial port and another version for using with ATmega2560 which has 4 UART ports.
But anyway - I’d like to know if it is possible to have a separate modified local libraries for each environment.
Because, there must be a reason why is the same library which is added automatically through lib_deps in platformio.ini installed twice - once for each environment.
Compiler and linker are obviously using the library corresponding to the active environment - despite both copies of the library in .pio\libdeps\uno and .pio\libdeps\megaatmega2560 are exactly the same.
Now that I copied those libraries into lib and made modifications, my code really has precedence over the code in .pio\libdeps\* and that works exactly as expected and as was described in the accepted answer that I linked. However, now both environments are using the very same local (modified) copy of the library.
My question is now if there is a way of telling: "When the active environment is uno then use lib\uno\* and when the active environment is megaatmega2560 then use lib\megaatmega2560\*.
In other words, is there a way to specify the lib path for each environment separately.
To include different libraries or directories which could contain your modified library, I would do it this way:
For instance you have defined your include_dir and src_dir globally and have created two [env:....] sections for your targets.
[platformio]
include_dir = includes
src_dir = sources
# global env
[env]
....
platform = ststm32
framework =
# this app would you library one
[env:application_1]
board=....
# only consider specific sources
build_src_filter= -<*> +<myAppSources> +<myLibraryOne>
# this app would you library two
[env:application_2]
board=....
# only consider specific sources
build_src_filter= -<*> +<myAppSources> +<myLibraryTwo>
build_src_filter can be used to filter directories or files that should be considered. build_src_filter= -<*> +<myAppSources> +<myLibraryTwo>
The -<*> firstly excludes all sources below ‘sources’ directory. The other add specific directories. In your case your application code and your libraries.
The ‘lib’ directory still could contain all other unmodified libraries that you need in your project.
The ‘sources’ directory contains your application sources and your modified libraries.