build: clean up the mess of ifdefs from platform into a scons-configured hal
This commit is contained in:
parent
236795917a
commit
23993a09cf
9
build-hal.py
Normal file
9
build-hal.py
Normal file
@ -0,0 +1,9 @@
|
||||
Import("env")
|
||||
board = env.get("BOARD_MCU")
|
||||
frameworks = env.get("PIOFRAMEWORK")
|
||||
|
||||
print(f"HAL configuration:")
|
||||
for framework in frameworks:
|
||||
env.Append(SRC_FILTER=[f"+<platform/{framework}/{board}/*>"])
|
||||
env.Append(SRC_FILTER=[f"+<platform/{framework}/*.cpp>"])
|
||||
print(f"- platform/{framework}{board}")
|
@ -71,7 +71,7 @@ MainLoop::loop()
|
||||
Task* slowestTask = NULL;
|
||||
for(Task* task : scheduler) {
|
||||
//unsigned int start = millis();
|
||||
#if defined(BOARD_ESP32) or defined(BOARD_ESP8266)
|
||||
#if defined(ESP32) or defined(ESP8266)
|
||||
unsigned int start = ESP.getCycleCount();
|
||||
#else
|
||||
unsigned int start = millis();
|
||||
@ -79,7 +79,7 @@ MainLoop::loop()
|
||||
Log.verbose("Running %s", task->name);
|
||||
s_lastTaskName = task->name;
|
||||
task->loop();
|
||||
#if defined(BOARD_ESP32) or defined(BOARD_ESP8266)
|
||||
#if defined(ESP32) or defined(ESP8266)
|
||||
unsigned int runtime = (ESP.getCycleCount() - start) / 160000;
|
||||
#else
|
||||
unsigned int runtime = millis() - start;
|
||||
|
131
platformio.ini
131
platformio.ini
@ -8,20 +8,24 @@
|
||||
; Please visit documentation for the other options and examples
|
||||
; https://docs.platformio.org/page/projectconf.html
|
||||
|
||||
[env]
|
||||
extra_scripts = pre:verify-configs.py, pre:build-hal.py
|
||||
|
||||
[common_env_data]
|
||||
src_filter = "+<*> -<.git/> -<.svn/> -<platform/> -<inputs/> +<inputs/BPM.cpp> +<inputs/Serial.cpp> +<inputs/CircadianRhythm.cpp>"
|
||||
src_filter = +<*>, -<.git/>, -<.svn/>, -<platform/>
|
||||
lib_ldf_mode = chain+
|
||||
extra_scripts = verify-configs.py
|
||||
src_build_flags =
|
||||
-DRENDERBUG_VERSION=3
|
||||
-DRENDERBUG_LED_PIN=14
|
||||
-DRENDERBUG_LED_PACKING=RGB
|
||||
-DDEFAULT_PATTERN_INDEX=0
|
||||
-fstack-protector
|
||||
-Wall
|
||||
lib_deps_external =
|
||||
fastled/FastLED@^3.5.0
|
||||
thijse/ArduinoLog@^1.1.0
|
||||
bblanchon/ArduinoJson@^6.17.3
|
||||
JsonStreamingParser
|
||||
LittleFS
|
||||
|
||||
[config_u8display]
|
||||
@ -31,32 +35,10 @@ lib_deps =
|
||||
olikraus/U8g2@^2.34.15
|
||||
src_filter = "+<platform/arduino/U8Display.cpp>"
|
||||
|
||||
[config_mqtt]
|
||||
src_build_flags =
|
||||
-DCONFIG_MQTT
|
||||
lib_deps =
|
||||
knolleary/PubSubClient@^2.8.0
|
||||
src_filter = "+<platform/arduino/MQTTTelemetry.cpp>"
|
||||
|
||||
[config_wifi]
|
||||
src_build_flags =
|
||||
-DCONFIG_WIFI
|
||||
src_filter = "+<platform/arduino/WiFiTask.cpp>"
|
||||
|
||||
[config_bluetooth]
|
||||
src_build_flags =
|
||||
-DCONFIG_BLUETOOTH
|
||||
src_filter = "+<platform/arduino/BluetoothSerialTelemetry.cpp>"
|
||||
lib_deps =
|
||||
BluetoothSerial
|
||||
|
||||
[config_ota]
|
||||
src_build_flags =
|
||||
-DCONFIG_OTA
|
||||
src_filter = "+<platform/arduino/OTA.cpp>"
|
||||
lib_deps =
|
||||
ArduinoOTA
|
||||
ESP8266mDNS
|
||||
|
||||
[config_nocolor]
|
||||
src_build_flags =
|
||||
@ -72,28 +54,8 @@ src_build_flags =
|
||||
-DCONFIG_MPU5060
|
||||
src_filter = "+<inputs/MPU6050.cpp>"
|
||||
|
||||
[env:bike]
|
||||
extends = env:esp32, config_u8display
|
||||
src_filter = "${env:esp32.src_filter} ${config_u8display.src_filter}"
|
||||
lib_deps =
|
||||
${env:esp32.lib_deps}
|
||||
${config_u8display.lib_deps}
|
||||
src_build_flags =
|
||||
${env:esp32.src_build_flags}
|
||||
${config_u8display.src_build_flags}
|
||||
build_type = debug
|
||||
|
||||
[env:bike_ble]
|
||||
extends = env:bike
|
||||
lib_deps =
|
||||
${env:bike.lib_deps}
|
||||
nkolban/ESP32 BLE Arduino@1.0.1
|
||||
src_build_flags =
|
||||
${env:bike.src_build_flags}
|
||||
|
||||
[env:esp32]
|
||||
extends = config_nocolor
|
||||
extra_scripts = verify-configs.py
|
||||
board_build.filesystem = littlefs
|
||||
platform = espressif32
|
||||
board = featheresp32
|
||||
@ -103,11 +65,13 @@ check_flags =
|
||||
src_build_flags =
|
||||
${common_env_data.src_build_flags}
|
||||
${config_nocolor.src_build_flags}
|
||||
-DPLATFORM_ARDUINO
|
||||
-DBOARD_ESP32
|
||||
-DCONFIG_THREADED_INPUTS
|
||||
-DRENDERBUG_LED_PIN=14
|
||||
lib_deps =
|
||||
${common_env_data.lib_deps_external}
|
||||
BluetoothSerial
|
||||
knolleary/PubSubClient@^2.8.0
|
||||
src_filter = "${common_env_data.src_filter}"
|
||||
monitor_filters = esp32_exception_decoder
|
||||
monitor_speed = 115200
|
||||
@ -131,43 +95,19 @@ platform = espressif8266
|
||||
board = huzzah
|
||||
framework = arduino
|
||||
board_build.filesystem = littlefs
|
||||
monitor_filters = esp8266_exception_decoder
|
||||
src_build_flags =
|
||||
${common_env_data.src_build_flags}
|
||||
-DPLATFORM_ARDUINO
|
||||
-DBOARD_ESP8266
|
||||
-DCORE_DEBUG_LEVEL=5
|
||||
-fstack-protector
|
||||
lib_deps =
|
||||
${common_env_data.lib_deps_external}
|
||||
knolleary/PubSubClient@^2.8.0
|
||||
arduino-libraries/NTPClient@^3.1.0
|
||||
ESP8266WiFi
|
||||
ESP8266mDNS
|
||||
ArduinoOTA
|
||||
src_filter = "${common_env_data.src_filter}"
|
||||
|
||||
[env:esp32_bluetooth]
|
||||
extends = env:esp32, config_bluetooth
|
||||
src_filter = "${env:esp32.src_filter} ${config_mqtt.src_filter} ${config_wifi.src_filter} ${config_bluetooth.src_filter}"
|
||||
lib_deps =
|
||||
${env:esp32.lib_deps}
|
||||
${config_bluetooth.lib_deps}
|
||||
${config_mqtt.lib_deps}
|
||||
src_build_flags =
|
||||
${env:esp32.src_build_flags}
|
||||
${config_bluetooth.src_build_flags}
|
||||
${config_wifi.src_build_flags}
|
||||
-DRENDERBUG_LED_PIN=14
|
||||
|
||||
[env:esp32_wifi]
|
||||
extends = env:esp32, config_wifi, config_mqtt
|
||||
src_filter = "${env:esp32.src_filter} ${config_wifi.src_filter} ${config_mqtt.src_filter}"
|
||||
buid_type = debug
|
||||
lib_deps =
|
||||
${env:esp32.lib_deps}
|
||||
${config_mqtt.lib_deps}
|
||||
src_build_flags =
|
||||
${env:esp32.src_build_flags}
|
||||
${config_mqtt.src_build_flags}
|
||||
${config_wifi.src_build_flags}
|
||||
-DRENDERBUG_LED_PIN=14
|
||||
|
||||
[env:esp32_display]
|
||||
extends = env:esp32, config_u8display
|
||||
src_filter = "${env:esp32.src_filter} ${config_u8display.src_filter}"
|
||||
@ -179,46 +119,3 @@ src_build_flags =
|
||||
${env:esp32.src_build_flags}
|
||||
${config_u8display.src_build_flags}
|
||||
-DRENDERBUG_LED_PIN=14
|
||||
|
||||
[env:esp32_wifi_display]
|
||||
extends = env:esp32, config_wifi, config_mqtt, config_u8display
|
||||
src_filter = "${env:esp32.src_filter} ${config_wifi.src_filter} ${config_mqtt.src_filter} ${config_u8display.src_filter}"
|
||||
build_type = debug
|
||||
lib_deps =
|
||||
${env:esp32.lib_deps}
|
||||
${config_mqtt.lib_deps}
|
||||
${config_u8display.lib_deps}
|
||||
src_build_flags =
|
||||
${env:esp32.src_build_flags}
|
||||
${config_mqtt.src_build_flags}
|
||||
${config_wifi.src_build_flags}
|
||||
${config_u8display.src_build_flags}
|
||||
-DRENDERBUG_LED_PIN=14
|
||||
|
||||
[env:prototype]
|
||||
extends = env:esp32, config_buttons, config_mpu5060
|
||||
src_filter = "${env:esp32.src_filter} ${config_buttons.src_filter} ${config_mpu5060.src_filter}"
|
||||
|
||||
[env:esp8266_wifi]
|
||||
extends = env:esp8266, config_wifi, config_mqtt, config_ota
|
||||
src_filter = "${env:esp32.src_filter} ${config_ota.src_filter} ${config_wifi.src_filter} ${config_mqtt.src_filter}"
|
||||
src_build_flags =
|
||||
${env:esp8266.src_build_flags}
|
||||
${config_mqtt.src_build_flags}
|
||||
${config_wifi.src_build_flags}
|
||||
${config_ota.src_build_flags}
|
||||
lib_deps =
|
||||
${env:esp8266.lib_deps}
|
||||
${config_mqtt.lib_deps}
|
||||
ESP8266WiFi
|
||||
${config_ota.lib_deps}
|
||||
|
||||
#[env:home_lighting_grb]
|
||||
#extends = env:esp8266_wifi config_u8display
|
||||
#src_build_flags =
|
||||
# ${env:home_lighting.src_build_flags}
|
||||
# -DRENDERBUG_LED_PACKING=GRB
|
||||
|
||||
#[env:home_lighting-12f]
|
||||
#extends = env:esp8266_wifi config_u8display
|
||||
#board = esp12e
|
||||
|
@ -3,10 +3,6 @@
|
||||
|
||||
#include <EEPROM.h>
|
||||
|
||||
#ifdef BOARD_ESP8266
|
||||
#include <ESP8266WiFi.h>
|
||||
#endif
|
||||
|
||||
#ifdef PLATFORM_PHOTON
|
||||
LEDStatus serialStatus = LEDStatus(RGB_COLOR_ORANGE, LED_PATTERN_FADE, LED_SPEED_FAST, LED_PRIORITY_BACKGROUND);
|
||||
LEDStatus configStatus = LEDStatus(RGB_COLOR_YELLOW, LED_PATTERN_FADE, LED_SPEED_NORMAL, LED_PRIORITY_IMPORTANT);
|
||||
@ -14,21 +10,6 @@ retained bool LAST_BOOT_WAS_FLASH;
|
||||
retained bool LAST_BOOT_WAS_SERIAL;
|
||||
#endif
|
||||
|
||||
#ifndef __NOINIT_ATTR // Pre-defined on esp32
|
||||
#define __NOINIT_ATTR __attribute__ ((section (".noinit")))
|
||||
#endif
|
||||
|
||||
#define SAFE_MODE_MAGIC 6942
|
||||
|
||||
__NOINIT_ATTR uint8_t s_rebootCount;
|
||||
__NOINIT_ATTR uint16_t s_forceSafeMode;
|
||||
|
||||
void
|
||||
BootOptions::forceSafeMode()
|
||||
{
|
||||
s_forceSafeMode = SAFE_MODE_MAGIC;
|
||||
}
|
||||
|
||||
void
|
||||
BootOptions::initPins()
|
||||
{
|
||||
@ -53,40 +34,7 @@ BootOptions::BootOptions()
|
||||
configStatus.setActive(isSetup);
|
||||
serialStatus.setActive(isSerial);
|
||||
#endif
|
||||
#ifdef BOARD_ESP32
|
||||
resetReason = esp_reset_reason();
|
||||
crashCount = s_rebootCount;
|
||||
if (resetReason >= 4) { // TODO: These values are defined in
|
||||
// esp32/rom/rtc.h, but not sure if that's included
|
||||
// on platformio builds
|
||||
if (crashCount++ >= 3) {
|
||||
// Boot into safe mode if the watchdog reset us three times in a row.
|
||||
isSafeMode = true;
|
||||
}
|
||||
} else {
|
||||
crashCount = 0;
|
||||
}
|
||||
s_rebootCount = crashCount;
|
||||
#endif
|
||||
#ifdef BOARD_ESP8266
|
||||
struct rst_info resetInfo = *ESP.getResetInfoPtr();
|
||||
resetReason = resetInfo.reason;
|
||||
crashCount = s_rebootCount;
|
||||
if (resetInfo.reason == REASON_SOFT_WDT_RST || resetInfo.reason == REASON_WDT_RST || resetInfo.reason == REASON_EXCEPTION_RST) {
|
||||
if (crashCount++ >= 3) {
|
||||
// Boot into safe mode if the watchdog reset us three times in a row.
|
||||
isSafeMode = true;
|
||||
}
|
||||
} else {
|
||||
crashCount = 0;
|
||||
}
|
||||
s_rebootCount = crashCount;
|
||||
|
||||
if (resetInfo.reason > 0 && s_forceSafeMode == SAFE_MODE_MAGIC) {
|
||||
isSafeMode = true;
|
||||
s_forceSafeMode = 0;
|
||||
}
|
||||
#endif
|
||||
PlatformImpl<>::initBootOptions(*this);
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -1,5 +1,6 @@
|
||||
#pragma once
|
||||
#include <Arduino.h>
|
||||
#include "Hal.h"
|
||||
|
||||
struct BootOptions {
|
||||
static void initPins();
|
||||
@ -7,7 +8,6 @@ struct BootOptions {
|
||||
BootOptions();
|
||||
|
||||
void waitForRelease();
|
||||
void forceSafeMode();
|
||||
|
||||
bool isSetup = false;
|
||||
bool isSerial = false;
|
||||
|
@ -6,10 +6,10 @@ filename_iterator::filename_iterator()
|
||||
{}
|
||||
|
||||
filename_iterator::filename_iterator(const char* path, const char* suffix)
|
||||
#ifdef BOARD_ESP8266
|
||||
#ifdef ESP8266
|
||||
: dir(LittleFS.openDir(path)),
|
||||
#endif
|
||||
#ifdef BOARD_ESP32
|
||||
#ifdef ESP32
|
||||
: dir(LittleFS.open(path)),
|
||||
#endif
|
||||
valid(true),
|
||||
@ -26,7 +26,7 @@ filename_iterator::next()
|
||||
}
|
||||
int extPos = -1;
|
||||
do {
|
||||
#ifdef BOARD_ESP8266
|
||||
#ifdef ESP8266
|
||||
valid = dir.next();
|
||||
if (valid) {
|
||||
String fname = dir.fileName();
|
||||
@ -36,7 +36,7 @@ filename_iterator::next()
|
||||
}
|
||||
}
|
||||
#endif
|
||||
#ifdef BOARD_ESP32
|
||||
#ifdef ESP32
|
||||
File next = dir.openNextFile();
|
||||
valid = (bool)next;
|
||||
if (valid && !next.isDirectory()) {
|
||||
|
@ -24,10 +24,10 @@ struct filename_iterator: public std::iterator<std::input_iterator_tag, const ch
|
||||
bool valid;
|
||||
const char* suffix;
|
||||
|
||||
#ifdef BOARD_ESP8266
|
||||
#ifdef ESP8266
|
||||
Dir dir;
|
||||
#endif
|
||||
#ifdef BOARD_ESP32
|
||||
#ifdef ESP32
|
||||
File dir;
|
||||
#endif
|
||||
};
|
||||
|
30
src/Hal.h
Normal file
30
src/Hal.h
Normal file
@ -0,0 +1,30 @@
|
||||
#pragma once
|
||||
|
||||
struct BootOptions;
|
||||
|
||||
typedef enum {
|
||||
HAL_UNKNOWN,
|
||||
HAL_ESP32,
|
||||
HAL_ESP8266
|
||||
} HalBackend;
|
||||
|
||||
constexpr HalBackend DefaultBackend = HAL_ESP8266;
|
||||
|
||||
template<HalBackend Backend = DefaultBackend>
|
||||
class PlatformImpl {
|
||||
public:
|
||||
static const char* name();
|
||||
static const char* version();
|
||||
static int freeRam();
|
||||
static void startWatchdog();
|
||||
static void startNTP();
|
||||
static bool getLocalTime(struct tm* timedata, int timezone);
|
||||
static void loop();
|
||||
static const char* deviceID();
|
||||
__attribute__((noreturn)) static void restart();
|
||||
static void bootSplash();
|
||||
static void printCrashInfo();
|
||||
|
||||
static void initBootOptions(BootOptions& opts);
|
||||
static void forceSafeMode();
|
||||
};
|
120
src/Platform.cpp
120
src/Platform.cpp
@ -3,40 +3,16 @@
|
||||
#include "Static.h"
|
||||
#include <time.h>
|
||||
|
||||
#ifdef BOARD_ESP32
|
||||
#ifdef CONFIG_WIFI
|
||||
#include <WiFi.h>
|
||||
#endif
|
||||
#include <esp_task_wdt.h>
|
||||
#elif defined(BOARD_ESP8266)
|
||||
#ifdef CONFIG_WIFI
|
||||
#include <ESP8266WiFi.h>
|
||||
#include <WiFiUdp.h>
|
||||
#include <NTPClient.h>
|
||||
#include <ctime>
|
||||
|
||||
WiFiUDP wifiUdp;
|
||||
NTPClient timeClient(wifiUdp, "pool.ntp.org", 3600 * -7);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#ifdef PLATFORM_PHOTON
|
||||
STARTUP(BootOptions::initPins());
|
||||
#else
|
||||
#include "inputs/Serial.h"
|
||||
#ifdef CONFIG_MQTT
|
||||
#include "platform/arduino/MQTTTelemetry.h"
|
||||
#endif
|
||||
void printNewline(Print* logOutput, int logLevel)
|
||||
{
|
||||
(void)logLevel; // unused
|
||||
logOutput->print("\n");
|
||||
}
|
||||
int printEspLog(const char* fmt, va_list args)
|
||||
{
|
||||
Log.notice(fmt, args);
|
||||
return 1;
|
||||
}
|
||||
#endif
|
||||
|
||||
int Platform::s_timezone = 0;
|
||||
@ -46,24 +22,18 @@ Platform::TaskRegistration* Platform::lastTask = NULL;
|
||||
const char*
|
||||
Platform::name()
|
||||
{
|
||||
return PlatformImpl<>::name();
|
||||
#ifdef PLATFORM_PHOTON
|
||||
return "Photon";
|
||||
#elif defined(BOARD_ESP8266)
|
||||
return "ESP8266";
|
||||
#elif defined(BOARD_ESP32)
|
||||
return "ESP32";
|
||||
#else
|
||||
return "Unknown!";
|
||||
#endif
|
||||
}
|
||||
|
||||
const char*
|
||||
Platform::version()
|
||||
{
|
||||
return PlatformImpl<>::version();
|
||||
#ifdef PLATFORM_PHOTON
|
||||
return System.version().c_str();
|
||||
#elif defined(BOARD_ESP32) || defined(BOARD_ESP8266)
|
||||
return ESP.getSdkVersion();
|
||||
#else
|
||||
return "Unknown!";
|
||||
#endif
|
||||
@ -72,9 +42,7 @@ Platform::version()
|
||||
int
|
||||
Platform::freeRam()
|
||||
{
|
||||
#if defined(BOARD_ESP8266) || defined(BOARD_ESP32)
|
||||
return ESP.getFreeHeap();
|
||||
#endif
|
||||
return PlatformImpl<>::freeRam();
|
||||
}
|
||||
|
||||
void
|
||||
@ -94,26 +62,17 @@ Platform::preSetup()
|
||||
Log.notice("\xf0\x9f\x94\x8c Serial connected");
|
||||
}
|
||||
#else
|
||||
#ifdef CONFIG_MQTT
|
||||
Log.begin(LOG_LEVEL_TRACE, Static<MQTTTelemetry>::instance()->logPrinter());
|
||||
Static<MQTTTelemetry>::instance()->setSequencer(Static<Sequencer>::instance());
|
||||
#else
|
||||
Log.begin(LOG_LEVEL_TRACE, Static<SerialInput>::instance()->logPrinter());
|
||||
#endif
|
||||
Log.setSuffix(printNewline);
|
||||
#endif
|
||||
|
||||
#ifdef BOARD_ESP32
|
||||
esp_task_wdt_init(10, true);
|
||||
esp_task_wdt_add(NULL);
|
||||
esp_log_set_vprintf(printEspLog);
|
||||
#endif
|
||||
#ifdef BOARD_ESP8266
|
||||
ESP.wdtEnable(0);
|
||||
if (!ESP.checkFlashCRC()) {
|
||||
Log.fatal("Firmware failed CRC check!!!");
|
||||
}
|
||||
#endif
|
||||
PlatformImpl<>::startWatchdog();
|
||||
}
|
||||
|
||||
void
|
||||
@ -121,19 +80,15 @@ Platform::setup()
|
||||
{
|
||||
#ifdef PLATFORM_PHOTON
|
||||
Time.zone(Static<Platform>::instance()->getTimezone());
|
||||
#elif defined(BOARD_ESP32)
|
||||
constexpr int dst = 1;
|
||||
configTime(s_timezone* 3600, 3600 * dst, "pool.ntp.org");
|
||||
#elif defined(BOARD_ESP8266)
|
||||
#ifdef CONFIG_WIFI
|
||||
timeClient.begin();
|
||||
#endif
|
||||
#endif
|
||||
PlatformImpl<>::startNTP();
|
||||
}
|
||||
|
||||
void
|
||||
Platform::bootSplash()
|
||||
{
|
||||
PlatformImpl<>::bootSplash();
|
||||
|
||||
#ifdef PLATFORM_PHOTON
|
||||
Log.notice(u8" Boot pin configuration:");
|
||||
Log.notice(u8" 2: Setup - %d", bootopts.isSetup);
|
||||
@ -148,14 +103,7 @@ Platform::bootSplash()
|
||||
lastTaskBuf[15] = 0;
|
||||
Log.error(u8"Crash occurred in task %s", lastTaskBuf);
|
||||
|
||||
#ifdef BOARD_ESP8266
|
||||
auto rInfo = ESP.getResetInfoPtr();
|
||||
if (Platform::bootopts.resetReason == REASON_EXCEPTION_RST) {
|
||||
Log.error("Fatal exception (%d):", rInfo->exccause);
|
||||
}
|
||||
Log.error("epc1=%X, epc2=%X, epc3=%X, excvaddr=%X, depc=%X",
|
||||
rInfo->epc1, rInfo->epc2, rInfo->epc3, rInfo->excvaddr, rInfo->depc);
|
||||
#endif
|
||||
PlatformImpl<>::printCrashInfo();
|
||||
|
||||
strncpy(lastTaskBuf, Renderer::lastFigmentName(), sizeof(lastTaskBuf));
|
||||
lastTaskBuf[15] = 0;
|
||||
@ -164,7 +112,6 @@ Platform::bootSplash()
|
||||
|
||||
Log.trace("Startup reason: %d", bootopts.resetReason);
|
||||
|
||||
|
||||
Log.trace("Registered tasks:");
|
||||
auto it = beginTasks();
|
||||
while (it != endTasks()) {
|
||||
@ -180,16 +127,7 @@ Platform::bootSplash()
|
||||
void
|
||||
Platform::loop()
|
||||
{
|
||||
#ifdef BOARD_ESP8266
|
||||
#ifdef CONFIG_WIFI
|
||||
if (WiFi.status() == WL_CONNECTED) {
|
||||
timeClient.update();
|
||||
}
|
||||
#endif
|
||||
ESP.wdtFeed();
|
||||
#elif defined(BOARD_ESP32)
|
||||
esp_task_wdt_reset();
|
||||
#endif
|
||||
PlatformImpl<>::loop();
|
||||
}
|
||||
|
||||
bool
|
||||
@ -202,40 +140,19 @@ Platform::getLocalTime(struct tm* timedata)
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
#elif defined(BOARD_ESP32)
|
||||
time_t rawtime;
|
||||
memset(&rawtime, 0, sizeof(rawtime));
|
||||
time(&rawtime);
|
||||
(*timedata) = (*localtime(&rawtime));
|
||||
return (timedata->tm_year > (2016-1990));
|
||||
#else
|
||||
#ifdef CONFIG_WIFI
|
||||
timedata->tm_hour = timeClient.getHours();
|
||||
timedata->tm_min = timeClient.getMinutes();
|
||||
#else
|
||||
memset(timedata, sizeof(struct tm), 0);
|
||||
return false;
|
||||
#endif
|
||||
return true;
|
||||
#endif
|
||||
return PlatformImpl<>::getLocalTime(timedata, s_timezone);
|
||||
}
|
||||
|
||||
const char*
|
||||
Platform::deviceID()
|
||||
{
|
||||
uint64_t chipid;
|
||||
#ifdef BOARD_ESP32
|
||||
chipid = ESP.getEfuseMac();
|
||||
#elif defined(BOARD_ESP8266)
|
||||
chipid = ESP.getChipId();
|
||||
#endif
|
||||
snprintf(s_deviceID, sizeof(s_deviceID), "%08X", (uint32_t)chipid);
|
||||
return s_deviceID;
|
||||
return PlatformImpl<>::deviceID();
|
||||
}
|
||||
|
||||
void
|
||||
Platform::addLEDs(CRGB* leds, uint16_t ledCount) {
|
||||
FastLED.addLeds<WS2812, RENDERBUG_LED_PIN, RENDERBUG_LED_PACKING>(leds, ledCount);
|
||||
FastLED.addLeds<NEOPIXEL, RENDERBUG_LED_PIN>(leds, ledCount);
|
||||
}
|
||||
|
||||
const String
|
||||
@ -247,12 +164,7 @@ Platform::model()
|
||||
|
||||
void
|
||||
Platform::restart() {
|
||||
#ifdef BOARD_ESP8266
|
||||
ESP.wdtDisable();
|
||||
ESP.restart();
|
||||
#elif defined(BOARD_ESP32)
|
||||
ESP.restart();
|
||||
#endif
|
||||
PlatformImpl<>::restart();
|
||||
}
|
||||
|
||||
|
||||
@ -260,15 +172,15 @@ void
|
||||
Platform::doReboot(Args& args, Print& out)
|
||||
{
|
||||
out.println("Rebooting");
|
||||
Platform::restart();
|
||||
restart();
|
||||
}
|
||||
|
||||
void
|
||||
Platform::doSafeMode(Args& args, Print& out)
|
||||
{
|
||||
out.println("Rebooting into safe mode");
|
||||
Platform::bootopts.forceSafeMode();
|
||||
Platform::restart();
|
||||
PlatformImpl<>::forceSafeMode();
|
||||
restart();
|
||||
}
|
||||
|
||||
String s;
|
||||
|
@ -2,6 +2,7 @@
|
||||
#include <FastLED.h>
|
||||
#include <Figments.h>
|
||||
#include "BootOptions.h"
|
||||
#include "Hal.h"
|
||||
|
||||
class Platform : public Task {
|
||||
static int s_timezone;
|
||||
|
@ -1,5 +0,0 @@
|
||||
#include "./ConfigInput.h"
|
||||
#include "./Static.h"
|
||||
|
||||
STATIC_ALLOC(ConfigInput);
|
||||
STATIC_TASK(ConfigInput);
|
@ -1,77 +0,0 @@
|
||||
#pragma once
|
||||
#include <Figments.h>
|
||||
|
||||
class ConfigInputTask : public BufferedInputSource {
|
||||
public:
|
||||
ConfigInputTask() : BufferedInputSource("ConfigInput") {}
|
||||
|
||||
void handleEvent(const InputEvent& evt) override {
|
||||
if (evt.intent == InputEvent::UserInput) {
|
||||
Buttons::Chord chord = (Buttons::Chord) evt.asInt();
|
||||
switch (chord) {
|
||||
case Buttons::Circle:
|
||||
m_currentIntent = nextIntent();
|
||||
//Log.info("Next setting... (%d)", m_currentIntent);
|
||||
break;
|
||||
case Buttons::CircleTriangle:
|
||||
//Log.info("Increment...");
|
||||
increment();
|
||||
break;
|
||||
case Buttons::CircleCross:
|
||||
//Log.info("Decrement...");
|
||||
decrement();
|
||||
break;
|
||||
case Buttons::Triangle:
|
||||
//Log.info("Save...");
|
||||
setEvent(InputEvent::SaveConfigurationRequest);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private:
|
||||
InputEvent::Intent m_currentIntent = InputEvent::SetDisplayLength;
|
||||
|
||||
void decrement() {
|
||||
int current = 0;
|
||||
switch (m_currentIntent) {
|
||||
case InputEvent::SetDisplayLength:
|
||||
current = Static<ConfigService>::instance()->coordMap()->pixelCount;
|
||||
break;
|
||||
case InputEvent::SetDisplayOffset:
|
||||
current = Static<ConfigService>::instance()->coordMap()->startPixel;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
setEvent(InputEvent{m_currentIntent, current - 1});
|
||||
}
|
||||
|
||||
void increment() {
|
||||
int current = 0;
|
||||
switch (m_currentIntent) {
|
||||
case InputEvent::SetDisplayLength:
|
||||
current = Static<ConfigService>::instance()->coordMap()->pixelCount;
|
||||
break;
|
||||
case InputEvent::SetDisplayOffset:
|
||||
current = Static<ConfigService>::instance()->coordMap()->startPixel;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
setEvent(InputEvent{m_currentIntent, current + 1});
|
||||
}
|
||||
|
||||
InputEvent::Intent nextIntent() {
|
||||
switch (m_currentIntent) {
|
||||
case InputEvent::SetDisplayLength:
|
||||
return InputEvent::SetDisplayOffset;
|
||||
case InputEvent::SetDisplayOffset:
|
||||
return InputEvent::SetDisplayLength;
|
||||
default:
|
||||
return InputEvent::None;
|
||||
}
|
||||
}
|
||||
};
|
@ -31,7 +31,7 @@ const MQTTDevice Device{
|
||||
Platform::deviceID(),
|
||||
Platform::deviceName(),
|
||||
Platform::model(),
|
||||
#ifdef BOARD_ESP8266
|
||||
#ifdef ESP8266
|
||||
ESP.getSketchMD5(),
|
||||
#else
|
||||
"",
|
||||
@ -95,10 +95,6 @@ const MQTTEntity Lightswitch {
|
||||
"light", Device, "lightswitch"
|
||||
};
|
||||
|
||||
const MQTTEntity flashlightSwitch {
|
||||
"switch", Device, "flashlight"
|
||||
};
|
||||
|
||||
const MQTTEntity FPSSensor {
|
||||
"sensor", Device, "fps"
|
||||
};
|
||||
@ -124,27 +120,28 @@ MQTTTelemetry::handleEventOnline(const InputEvent& evt)
|
||||
|
||||
m_json.clear();
|
||||
Lightswitch.toJson(m_json);
|
||||
|
||||
int i = 0;
|
||||
for(const Sequencer::Scene& scene : m_sequencer->scenes()) {
|
||||
m_json["fx_list"][i++] = scene.name;
|
||||
}
|
||||
m_json["brightness"] = true;
|
||||
m_json["rgb"] = true;
|
||||
|
||||
publishDoc(Lightswitch.configTopic().c_str(), true);
|
||||
|
||||
//Log.verbose("Publish %s %s", Lightswitch.configTopic().c_str(), buf);
|
||||
//m_mqtt.publish(Lightswitch.configTopic().c_str(), (uint8_t*)buf, strlen(buf), true);
|
||||
m_mqtt.subscribe(Lightswitch.commandTopic().c_str());
|
||||
|
||||
m_json.clear();
|
||||
flashlightSwitch.toJson(m_json, false);
|
||||
m_json["cmd_t"] = "~/set";
|
||||
m_json["ret"] = true;
|
||||
publishDoc(flashlightSwitch.configTopic().c_str(), true);
|
||||
//m_mqtt.publish(flashlightSwitch.configTopic().c_str(), (uint8_t*)buf, strlen(buf), true);
|
||||
m_mqtt.subscribe(flashlightSwitch.commandTopic().c_str());
|
||||
for(auto scene : Static<Sequencer>::instance()->scenes()) {
|
||||
m_json.clear();
|
||||
String strName{scene.name};
|
||||
MQTTEntity sceneObj {
|
||||
"scene",
|
||||
Device,
|
||||
strName
|
||||
};
|
||||
sceneObj.toJson(m_json, false);
|
||||
m_json["cmd_t"] = "~/set";
|
||||
m_json["ret"] = false;
|
||||
m_json["payload_on"] = "active";
|
||||
publishDoc(sceneObj.configTopic().c_str(), false);
|
||||
m_mqtt.subscribe(sceneObj.commandTopic().c_str());
|
||||
Log.info("Published scene %s", sceneObj.configTopic().c_str());
|
||||
}
|
||||
|
||||
m_json.clear();
|
||||
FPSSensor.toJson(m_json, false);
|
||||
@ -168,13 +165,7 @@ MQTTTelemetry::handleEventOnline(const InputEvent& evt)
|
||||
}
|
||||
} else {
|
||||
String statTopic = Lightswitch.statTopic();
|
||||
if (evt.intent == InputEvent::StopThing && String(evt.asString()) == "Flashlight") {
|
||||
String flashlightStatTopic = flashlightSwitch.statTopic();
|
||||
m_mqtt.publish(flashlightStatTopic.c_str(), "OFF");
|
||||
} else if (evt.intent == InputEvent::StartThing && String(evt.asString()) == "Flashlight") {
|
||||
String flashlightStatTopic = flashlightSwitch.statTopic();
|
||||
m_mqtt.publish(flashlightStatTopic.c_str(), "ON");
|
||||
} else if (evt.intent == InputEvent::SetPower) {
|
||||
if (evt.intent == InputEvent::SetPower) {
|
||||
m_json.clear();
|
||||
m_isOn = evt.asInt() ? true : false;
|
||||
m_json["state"] = m_isOn ? "ON" : "OFF";
|
||||
@ -192,7 +183,7 @@ MQTTTelemetry::handleEventOnline(const InputEvent& evt)
|
||||
m_json["color"]["b"] = color.b;
|
||||
m_json["state"] = m_isOn ? "ON" : "OFF";
|
||||
publishDoc(statTopic.c_str());
|
||||
} else if (evt.intent == InputEvent::SetPattern) {
|
||||
} else if (evt.intent == InputEvent::SetScene) {
|
||||
m_json.clear();
|
||||
m_json["effect"] = evt.asString();
|
||||
m_json["state"] = m_isOn ? "ON" : "OFF";
|
||||
@ -280,17 +271,7 @@ void
|
||||
MQTTTelemetry::callback(char* topic, const char* payload)
|
||||
{
|
||||
setEvent(InputEvent::NetworkActivity);
|
||||
if (flashlightSwitch.isCommandTopic(topic)) {
|
||||
if (!strncmp((char*)payload, "ON", sizeof("ON"))) {
|
||||
Log.notice("Turning on flashlight");
|
||||
setEvent(InputEvent{InputEvent::SetPower, true});
|
||||
setEvent(InputEvent{InputEvent::SetPattern, "Flashlight"});
|
||||
setEvent(InputEvent{InputEvent::SetBrightness, 255});
|
||||
} else if (!strncmp((char*)payload, "OFF", sizeof("OFF"))) {
|
||||
Log.notice("Turning off flashlight");
|
||||
setEvent(InputEvent{InputEvent::SetPattern, "Idle"});
|
||||
}
|
||||
} else if (Lightswitch.isCommandTopic(topic)) {
|
||||
if (Lightswitch.isCommandTopic(topic)) {
|
||||
deserializeJson(m_json, payload);
|
||||
|
||||
if (m_json.containsKey("state")) {
|
||||
@ -299,7 +280,7 @@ MQTTTelemetry::callback(char* topic, const char* payload)
|
||||
setEvent(InputEvent{InputEvent::SetPower, true});
|
||||
} else if (m_json["state"] == "OFF") {
|
||||
Log.notice("Turning off power");
|
||||
setEvent(InputEvent{InputEvent::SetPattern, "Idle"});
|
||||
setEvent(InputEvent{InputEvent::SetScene, "Idle"});
|
||||
setEvent(InputEvent{InputEvent::SetPower, false});
|
||||
}
|
||||
}
|
||||
@ -352,7 +333,7 @@ MQTTTelemetry::callback(char* topic, const char* payload)
|
||||
|
||||
if (m_json.containsKey("effect")) {
|
||||
strcpy(m_patternBuf, m_json["effect"].as<const char*>());
|
||||
setEvent(InputEvent{InputEvent::SetPattern, m_patternBuf});
|
||||
setEvent(InputEvent{InputEvent::SetScene, m_patternBuf});
|
||||
}
|
||||
|
||||
if (m_json.containsKey("color")) {
|
||||
@ -367,6 +348,19 @@ MQTTTelemetry::callback(char* topic, const char* payload)
|
||||
}
|
||||
|
||||
Log.notice("Event done.");
|
||||
} else {
|
||||
for(auto scene : Static<Sequencer>::instance()->scenes()) {
|
||||
String strName{scene.name};
|
||||
MQTTEntity sceneObj {
|
||||
"scene",
|
||||
Device,
|
||||
strName
|
||||
};
|
||||
if (sceneObj.isCommandTopic(topic)) {
|
||||
setEvent(InputEvent{InputEvent::SetScene, scene.name});
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -7,9 +7,9 @@
|
||||
|
||||
#include "../../Sequencer.h"
|
||||
|
||||
#ifdef BOARD_ESP8266
|
||||
#ifdef ESP8266
|
||||
#include <ESP8266WiFi.h>
|
||||
#elif defined(BOARD_ESP32)
|
||||
#elif defined(ESP32)
|
||||
#include <WiFi.h>
|
||||
#endif
|
||||
|
||||
|
@ -1,10 +1,10 @@
|
||||
#include <Input.h>
|
||||
#include <ArduinoLog.h>
|
||||
|
||||
#ifdef BOARD_ESP8266
|
||||
#ifdef ESP8266
|
||||
#include <ESP8266WiFi.h>
|
||||
#endif
|
||||
#ifdef BOARD_ESP32
|
||||
#ifdef ESP32
|
||||
#include <WiFi.h>
|
||||
#endif
|
||||
#include "Static.h"
|
||||
|
106
src/platform/arduino/esp32/Platform.cpp
Normal file
106
src/platform/arduino/esp32/Platform.cpp
Normal file
@ -0,0 +1,106 @@
|
||||
#include "../../../Platform.h"
|
||||
|
||||
#include <WiFi.h>
|
||||
#include <esp_task_wdt.h>
|
||||
|
||||
__NOINIT_ATTR static uint8_t s_rebootCount;
|
||||
__NOINIT_ATTR static uint16_t s_forceSafeMode;
|
||||
#define SAFE_MODE_MAGIC 6942
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP32>::initBootOptions(BootOptions& opts)
|
||||
{
|
||||
opts.resetReason = esp_reset_reason();
|
||||
opts.crashCount = s_rebootCount;
|
||||
if (opts.resetReason >= 4) { // TODO: These values are defined in
|
||||
// esp32/rom/rtc.h, but not sure if that's included
|
||||
// on platformio builds
|
||||
if (opts.crashCount++ >= 3) {
|
||||
// Boot into safe mode if the watchdog reset us three times in a row.
|
||||
isSafeMode = true;
|
||||
}
|
||||
} else {
|
||||
opts.crashCount = 0;
|
||||
}
|
||||
s_rebootCount = crashCount;
|
||||
}
|
||||
|
||||
template<>
|
||||
const char*
|
||||
PlatformImpl<HAL_ESP32>::name()
|
||||
{
|
||||
return "ESP32";
|
||||
}
|
||||
|
||||
template<>
|
||||
const char*
|
||||
PlatformImpl<HAL_ESP32>::version()
|
||||
{
|
||||
return ESP.getSdkVersion();
|
||||
}
|
||||
|
||||
template<>
|
||||
const char*
|
||||
PlatformImpl<HAL_ESP32>::deviceID()
|
||||
{
|
||||
uint64_t chipid;
|
||||
chipid = ESP.getEfuseMac();
|
||||
snprintf(s_deviceID, sizeof(s_deviceID), "%08X", (uint32_t)chipid);
|
||||
return s_deviceID;
|
||||
}
|
||||
|
||||
template<>
|
||||
int
|
||||
PlatformImpl<HAL_ESP32>::freeRam()
|
||||
{
|
||||
return ESP.getFreeHeap();
|
||||
}
|
||||
|
||||
int printEspLog(const char* fmt, va_list args)
|
||||
{
|
||||
Log.notice(fmt, args);
|
||||
return 1;
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP32>::startWatchdog()
|
||||
{
|
||||
esp_task_wdt_init(10, true);
|
||||
esp_task_wdt_add(NULL);
|
||||
esp_log_set_vprintf(printEspLog);
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP32>::startNTP()
|
||||
{
|
||||
constexpr int dst = 1;
|
||||
configTime(0, 3600 * dst, "pool.ntp.org");
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP32>::loop()
|
||||
{
|
||||
esp_task_wdt_reset();
|
||||
}
|
||||
|
||||
template<>
|
||||
bool
|
||||
PlatformImpl<HAL_ESP32>::getLocalTime(struct tm* timedata, int timezone)
|
||||
{
|
||||
time_t rawtime;
|
||||
memset(&rawtime, 0, sizeof(rawtime));
|
||||
time(&rawtime);
|
||||
(*timedata) = (*localtime(&rawtime));
|
||||
return (timedata->tm_year > (2016-1990));
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP32>::restart()
|
||||
{
|
||||
ESP.restart();
|
||||
}
|
134
src/platform/arduino/esp8266/Platform.cpp
Normal file
134
src/platform/arduino/esp8266/Platform.cpp
Normal file
@ -0,0 +1,134 @@
|
||||
#include "../../../Platform.h"
|
||||
#include <ESP8266WiFi.h>
|
||||
#include <WiFiUdp.h>
|
||||
#include <NTPClient.h>
|
||||
#include <ctime>
|
||||
|
||||
#define __NOINIT_ATTR __attribute__ ((section (".noinit")))
|
||||
__NOINIT_ATTR static uint8_t s_rebootCount;
|
||||
__NOINIT_ATTR static uint16_t s_forceSafeMode;
|
||||
#define SAFE_MODE_MAGIC 6942
|
||||
|
||||
WiFiUDP wifiUdp;
|
||||
NTPClient timeClient(wifiUdp, "pool.ntp.org", 3600 * -7);
|
||||
|
||||
template<>
|
||||
const char*
|
||||
PlatformImpl<HAL_ESP8266>::name()
|
||||
{
|
||||
return "ESP8266";
|
||||
}
|
||||
|
||||
template<>
|
||||
const char*
|
||||
PlatformImpl<HAL_ESP8266>::version()
|
||||
{
|
||||
return ESP.getSdkVersion();
|
||||
}
|
||||
|
||||
template<>
|
||||
int
|
||||
PlatformImpl<HAL_ESP8266>::freeRam()
|
||||
{
|
||||
return ESP.getFreeHeap();
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::startWatchdog()
|
||||
{
|
||||
ESP.wdtEnable(0);
|
||||
}
|
||||
|
||||
template<>
|
||||
bool
|
||||
PlatformImpl<HAL_ESP8266>::getLocalTime(struct tm* timedata, int timezone)
|
||||
{
|
||||
timedata->tm_hour = (timeClient.getHours() + timezone) % 23;
|
||||
timedata->tm_min = timeClient.getMinutes();
|
||||
return true;
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::startNTP()
|
||||
{
|
||||
timeClient.begin();
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::loop()
|
||||
{
|
||||
if (WiFi.status() == WL_CONNECTED) {
|
||||
timeClient.update();
|
||||
}
|
||||
ESP.wdtFeed();
|
||||
}
|
||||
|
||||
template<>
|
||||
const char*
|
||||
PlatformImpl<HAL_ESP8266>::deviceID()
|
||||
{
|
||||
static char s_deviceID[15];
|
||||
static uint16_t chipid = ESP.getChipId();
|
||||
snprintf(s_deviceID, sizeof(s_deviceID), "%08X", (uint32_t)chipid);
|
||||
return s_deviceID;
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::restart()
|
||||
{
|
||||
ESP.wdtDisable();
|
||||
ESP.restart();
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::bootSplash()
|
||||
{
|
||||
Log.notice("ESP8266!");
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::printCrashInfo()
|
||||
{
|
||||
auto rInfo = ESP.getResetInfoPtr();
|
||||
if (Platform::bootopts.resetReason == REASON_EXCEPTION_RST) {
|
||||
Log.error("Fatal exception (%d):", rInfo->exccause);
|
||||
}
|
||||
Log.error("epc1=%X, epc2=%X, epc3=%X, excvaddr=%X, depc=%X",
|
||||
rInfo->epc1, rInfo->epc2, rInfo->epc3, rInfo->excvaddr, rInfo->depc);
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::initBootOptions(BootOptions& opts)
|
||||
{
|
||||
struct rst_info resetInfo = *ESP.getResetInfoPtr();
|
||||
opts.resetReason = resetInfo.reason;
|
||||
opts.crashCount = s_rebootCount;
|
||||
if (resetInfo.reason == REASON_SOFT_WDT_RST || resetInfo.reason == REASON_WDT_RST || resetInfo.reason == REASON_EXCEPTION_RST) {
|
||||
if (opts.crashCount++ >= 3) {
|
||||
// Boot into safe mode if the watchdog reset us three times in a row.
|
||||
opts.isSafeMode = true;
|
||||
}
|
||||
} else {
|
||||
opts.crashCount = 0;
|
||||
}
|
||||
s_rebootCount = opts.crashCount;
|
||||
|
||||
if (resetInfo.reason > 0 && s_forceSafeMode == SAFE_MODE_MAGIC) {
|
||||
opts.isSafeMode = true;
|
||||
s_forceSafeMode = 0;
|
||||
}
|
||||
}
|
||||
|
||||
template<>
|
||||
void
|
||||
PlatformImpl<HAL_ESP8266>::forceSafeMode()
|
||||
{
|
||||
s_forceSafeMode = SAFE_MODE_MAGIC;
|
||||
}
|
@ -11,4 +11,21 @@ def verify_json(source, target, env):
|
||||
print("Validating " + root + '/' + file + '...')
|
||||
json.load(open(root + '/' + file, 'r'))
|
||||
|
||||
usedTasks = set()
|
||||
|
||||
for root, dirnames, files in os.walk("data/profiles/"):
|
||||
for file in files:
|
||||
if file.endswith(".json"):
|
||||
data = json.load(open(root + '/' + file, 'r'))
|
||||
for task in data['tasks']:
|
||||
usedTasks.add(task)
|
||||
|
||||
for sceneName in data['scenes']:
|
||||
for task in data['scenes'][sceneName]:
|
||||
usedTasks.add(task)
|
||||
|
||||
print("Used tasks:")
|
||||
for task in sorted(usedTasks):
|
||||
print("- " + task)
|
||||
|
||||
env.AddPreAction("buildfs", verify_json)
|
||||
|
Loading…
x
Reference in New Issue
Block a user