From 80c4062b29003d8f7da93e784cd72fee2456fd7f Mon Sep 17 00:00:00 2001
From: Moritz Perschke <moritz.perschke@uibk.ac.at>
Date: Fri, 29 Jul 2022 15:29:24 +0200
Subject: [PATCH] initialized platformio project

---
 client/client/.gitignore              |  6 ++++
 client/client/.vscode/extensions.json | 10 ++++++
 client/client/include/README          | 39 +++++++++++++++++++++++
 client/client/lib/README              | 46 +++++++++++++++++++++++++++
 client/client/platformio.ini          | 14 ++++++++
 client/client/src/main.cpp            |  9 ++++++
 client/client/test/README             | 11 +++++++
 7 files changed, 135 insertions(+)
 create mode 100644 client/client/.gitignore
 create mode 100644 client/client/.vscode/extensions.json
 create mode 100644 client/client/include/README
 create mode 100644 client/client/lib/README
 create mode 100644 client/client/platformio.ini
 create mode 100644 client/client/src/main.cpp
 create mode 100644 client/client/test/README

diff --git a/client/client/.gitignore b/client/client/.gitignore
new file mode 100644
index 0000000..6dea820
--- /dev/null
+++ b/client/client/.gitignore
@@ -0,0 +1,6 @@
+.pio
+.vscode/.browse.c_cpp.db*
+.vscode/c_cpp_properties.json
+.vscode/launch.json
+.vscode/ipch
+!lib/
diff --git a/client/client/.vscode/extensions.json b/client/client/.vscode/extensions.json
new file mode 100644
index 0000000..080e70d
--- /dev/null
+++ b/client/client/.vscode/extensions.json
@@ -0,0 +1,10 @@
+{
+    // See http://go.microsoft.com/fwlink/?LinkId=827846
+    // for the documentation about the extensions.json format
+    "recommendations": [
+        "platformio.platformio-ide"
+    ],
+    "unwantedRecommendations": [
+        "ms-vscode.cpptools-extension-pack"
+    ]
+}
diff --git a/client/client/include/README b/client/client/include/README
new file mode 100644
index 0000000..194dcd4
--- /dev/null
+++ b/client/client/include/README
@@ -0,0 +1,39 @@
+
+This directory is intended for project header files.
+
+A header file is a file containing C declarations and macro definitions
+to be shared between several project source files. You request the use of a
+header file in your project source file (C, C++, etc) located in `src` folder
+by including it, with the C preprocessing directive `#include'.
+
+```src/main.c
+
+#include "header.h"
+
+int main (void)
+{
+ ...
+}
+```
+
+Including a header file produces the same results as copying the header file
+into each source file that needs it. Such copying would be time-consuming
+and error-prone. With a header file, the related declarations appear
+in only one place. If they need to be changed, they can be changed in one
+place, and programs that include the header file will automatically use the
+new version when next recompiled. The header file eliminates the labor of
+finding and changing all the copies as well as the risk that a failure to
+find one copy will result in inconsistencies within a program.
+
+In C, the usual convention is to give header files names that end with `.h'.
+It is most portable to use only letters, digits, dashes, and underscores in
+header file names, and at most one dot.
+
+Read more about using header files in official GCC documentation:
+
+* Include Syntax
+* Include Operation
+* Once-Only Headers
+* Computed Includes
+
+https://gcc.gnu.org/onlinedocs/cpp/Header-Files.html
diff --git a/client/client/lib/README b/client/client/lib/README
new file mode 100644
index 0000000..6debab1
--- /dev/null
+++ b/client/client/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 a 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
diff --git a/client/client/platformio.ini b/client/client/platformio.ini
new file mode 100644
index 0000000..e36a50f
--- /dev/null
+++ b/client/client/platformio.ini
@@ -0,0 +1,14 @@
+; PlatformIO Project Configuration File
+;
+;   Build options: build flags, source filter
+;   Upload options: custom upload port, speed and extra flags
+;   Library options: dependencies, extra library storages
+;   Advanced options: extra scripting
+;
+; Please visit documentation for the other options and examples
+; https://docs.platformio.org/page/projectconf.html
+
+[env:esp32-c3-devkitm-1]
+platform = espressif32
+board = esp32-c3-devkitm-1
+framework = arduino
diff --git a/client/client/src/main.cpp b/client/client/src/main.cpp
new file mode 100644
index 0000000..58b344c
--- /dev/null
+++ b/client/client/src/main.cpp
@@ -0,0 +1,9 @@
+#include <Arduino.h>
+
+void setup() {
+  // put your setup code here, to run once:
+}
+
+void loop() {
+  // put your main code here, to run repeatedly:
+}
\ No newline at end of file
diff --git a/client/client/test/README b/client/client/test/README
new file mode 100644
index 0000000..9b1e87b
--- /dev/null
+++ b/client/client/test/README
@@ -0,0 +1,11 @@
+
+This directory is intended for PlatformIO Test Runner and project tests.
+
+Unit Testing is a software testing method by which individual units of
+source code, sets of one or more MCU program modules together with associated
+control data, usage procedures, and operating procedures, are tested to
+determine whether they are fit for use. Unit testing finds problems early
+in the development cycle.
+
+More information about PlatformIO Unit Testing:
+- https://docs.platformio.org/en/latest/advanced/unit-testing/index.html
-- 
GitLab