arduino-cli
arduino-cli copied to clipboard
Support bundling libraries with a sketch
Describe the request
š It will be easier for sketch developers to share a sketch as a package that includes library dependencies, avoiding the need for each user to install the library dependencies. š Library dependencies of the sketch can be controlled, allowing them to be pinned to the specific versions the sketch was intended to be used with, independent from the version of any globally installations of the library. As an example there are major changes to the API of the very popular "ArduinoJson" library in version 6 and sketches only work with one or the other major version series of that dependency.
Describe the current behavior
The common approach to bundling libraries with a sketch is to dump the library code files into the sketch root folder.
Arduino CLI version
a58d5adbe269ecc55778c007dc8ac39ffd42ce85
Operating system
All
Operating system version
All
Additional context
- As a workaround in the preferences the sketchbook location (
directories.user) can be set to the sketch folder. But this has to be done manually and changed every time another program is handled. So there could be some option for this to be set in the.inofile. - In the build folder a file
build.options.jsonis generated automatically. There are some options where additional library folders could possibly be added? E.g.:- builtInLibrariesFolders
- otherLibrariesFolders
Additional Requests
- https://github.com/arduino/arduino-cli/issues/1255#issuecomment-568900798
- https://github.com/arduino/arduino-cli/issues/1255#issuecomment-671084645
- https://github.com/arduino/arduino-cli/issues/1255#issuecomment-751318119
- https://github.com/arduino/arduino-cli/issues/1255#issuecomment-751483027
- https://github.com/arduino/arduino-cli/issues/1255#issuecomment-750951958
- https://github.com/arduino/arduino-cli/issues/1255#issuecomment-1476833890
- https://github.com/arduino/arduino-cli/issues/2763
- https://github.com/arduino/arduino-cli/issues/2818
- https://github.com/arduino/arduino-ide/issues/150#issuecomment-830714850
- https://github.com/arduino/arduino-ide/issues/2736
- https://forum.arduino.cc/t/how-do-i-include-a-library-in-a-sketch-directory/1079812
- https://forum.arduino.cc/t/arduino-ide-cant-find-local-custom-libraries-in-relative-path/669421
- https://forum.arduino.cc/t/suggestion-improve-library-manager/847666
- https://forum.arduino.cc/t/using-generated-headers/912691
- https://forum.arduino.cc/t/arduino-library-question/1349706
- https://forum.arduino.cc/t/compiling-a-complex-project/1365325
- https://forum.arduino.cc/t/use-arduino-with-specific-library/1371559
- https://forum.arduino.cc/t/per-project-libraries-in-ide-2-3-6/1401685
- https://forum.arduino.cc/t/how-to-create-a-complete-portable-sketch/1405328
- https://forum.arduino.cc/t/lvl-text-display/1350052/9
- https://forum.arduino.cc/t/the-annoyance-of-updating-libraries/1410769/8
Related
- https://forum.arduino.cc/t/local-libraries/1259854/1
- https://forum.arduino.cc/t/local-libraries/1259854/7
Issue checklist
- [X] I searched for previous requests in the issue tracker
- [X] I verified the feature was still missing when using the latest nightly build
- [X] My request contains all necessary details
I believe there are open issues about this already, did you look for them?
In any case, I'd really like to see the IDE support a libraries folder (as well as a hardware folder) inside the sketch directory, as you suggest here. That really helps to distribute a self-contained sketch, which is useful in some cases.
I looked for other open issues and found a couple related things, though none that would make this a duplicate:
- https://github.com/arduino/arduino-builder/pull/223 - Adds the requested feature, but only for zipped sketches.
- https://github.com/arduino/Arduino/issues/7555 - Doesn't seem to add anything of value beyond the information that was already in the https://github.com/arduino/arduino-builder/pull/223 thread.
The addition of recursive compilation of the src subfolder of the sketch folder does give us this feature to some extent. However, I suspect @hoblins is already aware of that option from their browsing of the forum discussions and found it to be unsatisfying.
The problem with bundling libraries in the src subfolder is that all use of the #include <foo.h> syntax in the bundled libraries for files in the src subfolder, which would work fine if the libraries were installed normally, must be changed to use relative paths to those files. Best practices would be for libraries to not use the #include <foo.h> syntax for internal dependencies anyway so I don't much mind changing those, but when you have dependencies between bundled libraries it gets ugly (e.g. #include <foo.h> -> #include "../../foo/src/foo.h").
+1 from my side! Especially if you want to have a project archived and ready to run after a couple of months/years Iād love to see the libraries in every sketch. Also when distributing sketches this feature would be awesome and is the next best thing (easiest) thing to do next to a full blown package manager Iād say.
Maybe PlatformIO is an option if you want this kind of functionality.
I want to add a +1 here too. I'm working on a series of sketches all utilizing the same set of core private headers, and having to make duplicate copies of them in every project because the compiler doesn't understand relative paths is a real pain in the neck. I have maybe half a dozen projects that need to #include "../../includes/somefile.h" and there doesn't seem to be any way to convince the arduino compiler to do this. Even just reverting to #include "somefile.h" and then making that file a symlink to the real file doesn't work.
I want to add a +1 here too. I'm working on a series of sketches all utilizing the same set of core private headers, and having to make duplicate copies of them in every project because the compiler doesn't understand relative paths is a real pain in the neck.
Huh? But how would the feature requested by this issue help here? This issue requests that a copy of a library inside the sketch folder can be used just like a normal shared library. For your usecase, it sounds like you just need to make your "core private headers" into a library, install it into your sketchook "libraries" directory along with the other libraries, and then you can just include these from all sketches that need them?
I want to add a +1 here too. I'm working on a series of sketches all utilizing the same set of core private headers, and having to make duplicate copies of them in every project because the compiler doesn't understand relative paths is a real pain in the neck.
Huh? But how would the feature requested by this issue help here? This issue requests that a copy of a library inside the sketch folder can be used just like a normal shared library. For your usecase, it sounds like you just need to make your "core private headers" into a library, install it into your sketchook "libraries" directory along with the other libraries, and then you can just include these from all sketches that need them?
You're right, the issue as it stands wouldn't be helpful. I was referring to per1234's message a few up where he mentions e.g. #include "../../foo/src/foo.h" which itself wouldn't work either.
My personal goal is to get away from using the Arduino IDE and to VS Code for a variety of reasons, so adding to some IDE specific library manager doesn't seem like a good path forward. The forums have indicated to me that including with relative paths simply doesn't work in the Arduino IDE because the files are copied somewhere else prior to compilation, and it seems like the VS Code arduino plugin seems to do the same thing (I guess?) before calling avr-gcc, or however it enters the ecosystem's toolchain.
I was referring to per1234's message a few up where he mentions e.g. #include "../../foo/src/foo.h" which itself wouldn't work either.
I should clarify that when I mentioned #include "../../foo/src/foo.h" in my previous reply, that was referring to the #include directives in a bundled library that has a dependency on another bundled library, not to #include directives in a sketch.
I'll provide a more detailed explanation:
Let's say you have a sketch with a structure like this:
MySketch
|_ MySketch.ino
|_ src
|_ bar
| |_library.properties
| |_src
| |_ bar.h
|_ foo
|_ library.properties
|_ src
|_ foo.h
With a normal library installation to the libraries subfolder of the sketchbook, if the "bar" library has a dependency on the "foo" library, it can just use #include <foo.h> and the Arduino library dependency resolution process automatically finds the "foo" library. However, if I want to bundle the "bar" and "foo" libraries with my sketch, as in my example structure above, then I must edit the "bar" library and modify #include <foo.h> to provide the relative path to foo.h: #include "../../foo/src/foo.h".
The forums have indicated to me...
Here's the forum thread @alandsidel mentioned: https://forum.arduino.cc/index.php?topic=699636
I can't believe how this is STILL not complete. It should be so easy to implement.
I can't believe how this is STILL not complete. It should be so easy to implement.
I agree. I've found temporary workaround for the time being. In addition to moving away from the Arduino IDE to VS Code, I decided to just make a symlink/junction in the Arduino libraries directory. This is undesireable because it's a manual process I have to remember to do in every development environment, or if/when I need to reinstall on my workstation, but at least it's something I can put in e.g. a readme & Makefile target for future reference.
It's disheartening that simple quality of life features like this for more experienced developers are seemingly rejected or delayed only because they might, sometimes, in rare instances, add a tiny bit of confusion to a beginner.
+1. It's would be super helpful if this can be implemented.
Editing libraries to support this or forcing the users to edit build options isn't the answer. Simple automatic support as in arduino/Arduino#11106 would allow us to use git submodules to keep larger projects in tact and properly versioned. Are there any targets or milestones for some sort of implementation or active development on a PR?
Editing libraries to support this or forcing the users to edit build options isn't the answer. Simple automatic support as in arduino/Arduino#11106 would allow us to use git submodules to keep larger projects in tact and properly versioned. Are there any targets or milestones for some sort of implementation or active development on a PR?
I'm really not in favor of making the "official" way to do this be via git submodules. Not all of us use git to manage every project, and even when we do, there are good reasons to not use submodules. This would force developers into choosing between not having the build chain work the way they expect like now, or to reorganize their code into submodules that may cause other problems elsewhere in their development cycle.
The problem is in the toolchain as it exists now, and that's where it should be fixed IMHO.
Editing libraries to support this or forcing the users to edit build options isn't the answer. Simple automatic support as in arduino/Arduino#11106 would allow us to use git submodules to keep larger projects in tact and properly versioned. Are there any targets or milestones for some sort of implementation or active development on a PR?
I'm really not in favor of making the "official" way to do this be via git submodules. Not all of us use git to manage every project, and even when we do, there are good reasons to not use submodules. This would force developers into choosing between not having the build chain work the way they expect like now, or to reorganize their code into submodules that may cause other problems elsewhere in their development cycle.
The problem is in the toolchain as it exists now, and that's where it should be fixed IMHO.
This has nothing to do with forcing the usage of git submodules. It just allows people to easily support them and keep local library code still separated. Did you even read it?
This has nothing to do with forcing the usage of git submodules. It just allows people to easily support them and keep local library code still separated. Did you even read it?
Yes, I did. Do you understand the problem mentioned by the issue you're posting in?
If the problem is fixed in the build tools, then submodules will automatically and transparently be supported without requiring special handling. There's no reason to add any special handling for git submodules, and the tool chain shouldn't even know or care what revision control system you're using, if any, in order to work properly.
This has nothing to do with forcing the usage of git submodules. It just allows people to easily support them and keep local library code still separated. Did you even read it?
Yes, I did. Do you understand the problem mentioned by the issue you're posting in?
If the problem is fixed in the build tools, then submodules will automatically and transparently be supported without requiring special handling. There's no reason to add any special handling for git submodules, and the tool chain shouldn't even know or care what revision control system you're using, if any, in order to work properly.
Yes, I did... It's called a use case. You could delete everything about git and submodules from my issue and it'll still stand. There's no special handling required. FFS read before you reply.
I implemented this feature and made a pull-request https://github.com/arduino/Arduino/pull/11110
Hi, what's the status on this feature?