summary refs log tree commit diff stats
path: root/firmware/lib/README
diff options
context:
space:
mode:
authorChristian Krinitsin <code@krinitsin.xyz>2024-12-21 22:10:45 +0100
committerChristian Krinitsin <code@krinitsin.xyz>2024-12-22 19:30:47 +0100
commit48ac28d8ea1f713451af339009bb1d589dde6cc6 (patch)
treeaada7cbf4213db62326f6cb369167c943ddfd03f /firmware/lib/README
downloadtetris-console-48ac28d8ea1f713451af339009bb1d589dde6cc6.tar.gz
tetris-console-48ac28d8ea1f713451af339009bb1d589dde6cc6.zip
init
Diffstat (limited to 'firmware/lib/README')
-rw-r--r--firmware/lib/README46
1 files changed, 46 insertions, 0 deletions
diff --git a/firmware/lib/README b/firmware/lib/README
new file mode 100644
index 0000000..2593a33
--- /dev/null
+++ b/firmware/lib/README
@@ -0,0 +1,46 @@
+
+This directory is intended for project specific (private) libraries.
+PlatformIO will compile them to static libraries and link into executable file.
+
+The source code of each library should be placed in an own separate directory
+("lib/your_library_name/[here are source files]").
+
+For example, see a structure of the following two libraries `Foo` and `Bar`:
+
+|--lib
+|  |
+|  |--Bar
+|  |  |--docs
+|  |  |--examples
+|  |  |--src
+|  |     |- Bar.c
+|  |     |- Bar.h
+|  |  |- library.json (optional, custom build options, etc) https://docs.platformio.org/page/librarymanager/config.html
+|  |
+|  |--Foo
+|  |  |- Foo.c
+|  |  |- Foo.h
+|  |
+|  |- README --> THIS FILE
+|
+|- platformio.ini
+|--src
+   |- main.c
+
+and a contents of `src/main.c`:
+```
+#include <Foo.h>
+#include <Bar.h>
+
+int main (void)
+{
+  ...
+}
+
+```
+
+PlatformIO Library Dependency Finder will find automatically dependent
+libraries scanning project source files.
+
+More information about PlatformIO Library Dependency Finder
+- https://docs.platformio.org/page/librarymanager/ldf.html