- Software development and build
Development is active on the VS Code + Platformio combination: you can download the complete repository and work directly.
Code is written to be compatible with the Arduino IDE, there are a couple of steps required, starting from the assumption you have already installed and setup the Arduino IDE for ESP32
- install the 'External libraries' listed in the section [deps] entry
lib_deps
ofplatform.ini
. See below an example of how and when to select a specific version - open the
bonogps.ino
file: it's empty as all in the code is somewhere else - choose your board: "ESP32 Dev Module" (the generic board that everyone has, often tagged DOIT) or "LOLIN D32 PRO" are supported, otherwise you might have to redefine your pins in
bonogps_board_settings.h
- choose a partition schema with enough space (e.g. the Minimal SPIFSS with 1.9Mb of flash space)
The rest is common to any other build on the Arduino IDE.
IF you are unsure of what board you are running, check this introductory tutorial.
You can update software OTA, check a later paragraph here on how as it's not enabled by default.
Beside install PlatformIO (on VS Code as a recommendation), the build system uses a custom python script to determine the current software release version: git_rev_macro.py
and it expects the project folder to be downloaded from github directly to build up the GIT_REV
and GIT_REPO
macro variables correctly.
If you are having issues, you can remove the line that invokes git_rev_macro.py
and optionally set the 2 macro GIT_REV
and GIT_REPO
manually.
If you would like to define custom targets for your build, I recommend using a platformio_custom.ini
file (there is a template in platformio_custom.ini.template
).
- NimBLE-Arduino: ^1.4.3 which means any minor update but within 1.X major
- Uptime Library ^1.0.0 which means any minor update but within 1.X major
- EasyButton specifically version 2.0.1: do not use any other version. This feature will be migrated to another library as EasyButton is no longer developed and the latest version is not working
- Task Scheduler ^3.2.0 which means any minor update but within 3.X major
On Arduino this would look like
Included via #define
options
- NeoGPS [not included right now, but coded and available for some additional cases]
Always included
- WebServer
- FS
- Preferences
- WiFi
- DNSServer
- ESPmDNS
- Update
- BluetoothSerial
Included via #define
statements or compile macros
- ArduinoOTA: this really depends on how you prefer to update software on your device. It adds size to the flash and it uses some memory, so if you don't plan on using it, don't include it.
To keep flash size small and to avoid several versions of the software, almost all features are enabled/disabled via macro preprocessing
For example, if you don't need BT-SPP or BLE, you can remove them. The most important ones are
BTSPPENABLED
Include BT-SPP capabilities (default: enabled)BLEENABLED
Include BLE capabilities (default: enabled)ENABLE_OTA
Include OTA capabilities (default: disabled)SHOWBATTERY
Display battery status for boards that have built-in (like LOLIN D32 PRO])
All logging on Serial Port is managed with log_<i/d/e/w>()
functions (read more at ESP32 Logging). You can control how much logging is enabled within the Arduino IDE from the Tools > Core Debug Level
menu.
OTA libraries are not enabled by default, to keep the binary size smaller and to have less software running at all times (it's a miracle there are no RAM issues with all tasks running).
Since updating via OTA is extremely convenient when you are testing, here is how to activate it via two preprocessing macro variables
ENABLE_OTA
if defined, libraries and code is builtin, if undefined no OTA is includedOTA_AVAILABILITY_SECS
defines for how long OTA is available after boot, either-1
(forever) or a finite number of seconds. If undefined, it's300
, to avoid any mistake on the field where you might mistakenly start flashing a firmare you are actually using
- uncomment
// #define ENABLE_OTA
at the beginning ofsrc/bonogps.cpp
(which you might have renamed tobonogps.ino
) - optionally, change for how long OTA is available definining
OTA_AVAILABILITY_SECS
- There are a couple of build targets ending in
_ota
that contain the command line define statements. If you need more build targets, I recommend using a localplatformio_custom.ini
that is not sync'd with the git repository - you can also permanently enable it changing the source code as for the Arduino case (not recommended)
You have to select a partitioning schema with 1.7 Mb of programming space (e.g. Minimal SPIFF with 1.9Mb), as the app with its libraries tend to be pretty large due to BT stacks.
Within PlatformIO, use the platformio.ini available configuration
board_build.partitions = min_spiffs.csv
Within the Arduino IDE, from Tools > Partition Scheme