From 1f89673fb72f9e5bec17ee19fa2092b31fee8276 Mon Sep 17 00:00:00 2001 From: Gregg Date: Sat, 21 May 2022 17:05:23 -0500 Subject: [PATCH] Updated 20-DynamicBridge to use std::array<> This allows the use of std::find(), std::remove, and iterator methods. Code is more intuitive. --- .../20-DynamicBridge/20-DynamicBridge.ino | 73 ++++++++++--------- 1 file changed, 40 insertions(+), 33 deletions(-) diff --git a/examples/20-DynamicBridge/20-DynamicBridge.ino b/examples/20-DynamicBridge/20-DynamicBridge.ino index aa6d5bc..4a31674 100644 --- a/examples/20-DynamicBridge/20-DynamicBridge.ino +++ b/examples/20-DynamicBridge/20-DynamicBridge.ino @@ -27,10 +27,10 @@ #include "HomeSpan.h" -#define MAX_LIGHTS 10 +#include nvs_handle savedData; -int accNum[MAX_LIGHTS+1]={0}; +std::array lights; ////////////////////////////////////// @@ -39,22 +39,21 @@ void setup() { Serial.begin(115200); size_t len; - nvs_open("SAVED_DATA",NVS_READWRITE,&savedData); // open SAVED DATA - if(!nvs_get_blob(savedData,"ACC_NUM",NULL,&len)) // if ACCESSORY NUMBER data found - nvs_get_blob(savedData,"ACC_NUM",&accNum,&len); // retrieve data + nvs_open("SAVED_DATA",NVS_READWRITE,&savedData); // open SAVED DATA + if(!nvs_get_blob(savedData,"LIGHTS",NULL,&len)) // if LIGHTS data found + nvs_get_blob(savedData,"LIGHTS",&lights,&len); // retrieve data homeSpan.setLogLevel(1); - homeSpan.begin(Category::Bridges,"HomeSpan Bridge"); + homeSpan.begin(Category::Lighting,"HomeSpan Lights"); new SpanAccessory(); new Service::AccessoryInformation(); new Characteristic::Identify(); new Characteristic::Model("HomeSpan Dynamic Bridge"); - for(int i=0;i0) - addLight(accNum[i]); + for(auto it=lights.begin(); it!=lights.end() && *it!=0; it++) + addLight(*it); new SpanUserCommand('a'," - add a new light accessory with id=",addAccessory); new SpanUserCommand('d'," - delete a light accessory with id=",deleteAccessory); @@ -102,24 +101,22 @@ void addAccessory(const char *buf){ return; } - int i; - for(i=0;i0 && accNum[i]!=n;i++); - - if(i==MAX_LIGHTS){ - Serial.printf("Can't add any more lights - max is %d!\n",MAX_LIGHTS); - return; - } - - if(accNum[i]>0){ + if(std::find(lights.begin(),lights.end(),n)!=lights.end()){ Serial.printf("Accessory Light-%d already implemented!\n",n); return; } + + auto it=std::find(lights.begin(),lights.end(),0); + + if(it==lights.end()){ + Serial.printf("Can't add any more lights - max is %d!\n",lights.size()); + return; + } - accNum[i]=n; - nvs_set_blob(savedData,"ACC_NUM",&accNum,sizeof(accNum)); // update data + *it=n; // save light number + nvs_set_blob(savedData,"LIGHTS",&lights,sizeof(lights)); // update data nvs_commit(savedData); - - addLight(n); + addLight(n); // add light accessory } /////////////////////////// @@ -140,22 +137,30 @@ void deleteAccessory(const char *buf){ Serial.printf("Deleting Accessory: Light-%d\n",n); - int i; // find entry in accNum - for(i=0;accNum[i]!=n;i++); - for(;i