Rework LED Strip detection to use Settings Manager
This commit is contained in:
parent
8eab2b6244
commit
73efb1735f
2 changed files with 38 additions and 44 deletions
|
|
@ -23,6 +23,13 @@
|
|||
#define strtok_s strtok_r
|
||||
#endif
|
||||
|
||||
struct LEDStripDevice
|
||||
{
|
||||
std::string port;
|
||||
unsigned int baud;
|
||||
unsigned int num_leds;
|
||||
};
|
||||
|
||||
class LEDStripController
|
||||
{
|
||||
public:
|
||||
|
|
|
|||
|
|
@ -2,21 +2,11 @@
|
|||
#include "LEDStripController.h"
|
||||
#include "RGBController.h"
|
||||
#include "RGBController_LEDStrip.h"
|
||||
#include "SettingsManager.h"
|
||||
#include <vector>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include <fcntl.h>
|
||||
#include <string.h>
|
||||
#include <fstream>
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
|
||||
#ifndef WIN32
|
||||
#include <unistd.h>
|
||||
#include <dirent.h>
|
||||
#endif
|
||||
|
||||
/******************************************************************************************\
|
||||
* *
|
||||
* DetectLEDStripControllers *
|
||||
|
|
@ -27,48 +17,45 @@
|
|||
|
||||
void DetectLEDStripControllers(std::vector<RGBController*> &rgb_controllers)
|
||||
{
|
||||
LEDStripController* new_ledstrip;
|
||||
LEDStripController* new_ledstrip;
|
||||
RGBController_LEDStrip* new_controller;
|
||||
json ledstrip_settings;
|
||||
LEDStripDevice dev;
|
||||
|
||||
std::ifstream infile;
|
||||
char arg1[64];
|
||||
/*-------------------------------------------------*\
|
||||
| Get LED Strip settings from settings manager |
|
||||
\*-------------------------------------------------*/
|
||||
ledstrip_settings = ResourceManager::get()->GetSettingsManager()->GetSettings("Setting_LEDStripDevices");
|
||||
|
||||
//Open settings file
|
||||
infile.open("ledstrip.txt");
|
||||
|
||||
if (infile.good())
|
||||
/*-------------------------------------------------*\
|
||||
| If the LEDStrip settings contains devices, process|
|
||||
\*-------------------------------------------------*/
|
||||
if(ledstrip_settings.contains("devices"))
|
||||
{
|
||||
for (std::string line; std::getline(infile, line); )
|
||||
for(unsigned int device_idx = 0; device_idx < ledstrip_settings["devices"].size(); device_idx++)
|
||||
{
|
||||
if (line == "")
|
||||
if(ledstrip_settings["devices"][device_idx].contains("port"))
|
||||
{
|
||||
continue;
|
||||
dev.port = ledstrip_settings["devices"][device_idx]["port"];
|
||||
}
|
||||
if ((line[0] != ';') && (line[0] != '#') && (line[0] != '/'))
|
||||
|
||||
if(ledstrip_settings["devices"][device_idx].contains("baud"))
|
||||
{
|
||||
char * argument;
|
||||
char * value;
|
||||
|
||||
value = (char *)line.c_str();
|
||||
|
||||
argument = strtok_s(value, "=", &value);
|
||||
|
||||
//Strip off new line characters if present
|
||||
argument = strtok(argument, "\r\n");
|
||||
value = strtok(value, "\r\n");
|
||||
|
||||
if(argument)
|
||||
{
|
||||
if (strcmp(argument, "ledstrip") == 0)
|
||||
{
|
||||
new_ledstrip = new LEDStripController();
|
||||
new_ledstrip->Initialize(value);
|
||||
|
||||
new_controller = new RGBController_LEDStrip(new_ledstrip);
|
||||
rgb_controllers.push_back(new_controller);
|
||||
}
|
||||
}
|
||||
dev.baud = ledstrip_settings["devices"][device_idx]["baud"];
|
||||
}
|
||||
|
||||
if(ledstrip_settings["devices"][device_idx].contains("num_leds"))
|
||||
{
|
||||
dev.num_leds = ledstrip_settings["devices"][device_idx]["num_leds"];
|
||||
}
|
||||
|
||||
std::string value = dev.port + "," + std::to_string(dev.baud) + "," + std::to_string(dev.num_leds);
|
||||
|
||||
new_ledstrip = new LEDStripController();
|
||||
new_ledstrip->Initialize((char *)value.c_str());
|
||||
|
||||
new_controller = new RGBController_LEDStrip(new_ledstrip);
|
||||
rgb_controllers.push_back(new_controller);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue