OVMS3/OVMS.V3/components/pcp/pcp.cpp

167 lines
4.4 KiB
C++

/*
; Project: Open Vehicle Monitor System
; Date: 14th March 2017
;
; Changes:
; 1.0 Initial release
;
; (C) 2011 Michael Stegen / Stegen Electronics
; (C) 2011-2017 Mark Webb-Johnson
; (C) 2011 Sonny Chen @ EPRO/DX
;
; Permission is hereby granted, free of charge, to any person obtaining a copy
; of this software and associated documentation files (the "Software"), to deal
; in the Software without restriction, including without limitation the rights
; to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
; copies of the Software, and to permit persons to whom the Software is
; furnished to do so, subject to the following conditions:
;
; The above copyright notice and this permission notice shall be included in
; all copies or substantial portions of the Software.
;
; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
; IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
; FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
; AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
; LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
; OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
; THE SOFTWARE.
*/
#include "ovms_log.h"
static const char *TAG = "pcp";
#include <stdio.h>
#include <string.h>
#include "pcp.h"
#include "ovms_events.h"
pcpapp MyPcpApp __attribute__ ((init_priority (4000)));
OvmsCommand* powercmd = NULL;
void power_cmd(int verbosity, OvmsWriter* writer, OvmsCommand* cmd, int argc, const char* const* argv)
{
const char* devname = cmd->GetParent()->GetName();
const char* pmname = cmd->GetName();
pcp* device = MyPcpApp.FindDeviceByName(devname);
PowerMode pm = MyPcpApp.FindPowerModeByName(pmname);
if ((device == NULL)||(pm == PowerMode::Undefined))
{
writer->puts("Internal error: finding device or power mode name failed");
return;
}
device->SetPowerMode(pm);
writer->printf("Power mode of %s is now %s\n",devname,pmname);
}
void power_status(int verbosity, OvmsWriter* writer, OvmsCommand* cmd, int argc, const char* const* argv)
{
const char* devname = cmd->GetParent()->GetName();
pcp* device = MyPcpApp.FindDeviceByName(devname);
const char* pmname = MyPcpApp.FindPowerModeByType(device->GetPowerMode());
writer->printf("Power for %s is %s\n",devname,pmname);
}
pcpapp::pcpapp()
{
ESP_LOGI(TAG, "Initialising POWER (4000)");
m_mappm["on"] = On;
m_mappm["sleep"] = Sleep;
m_mappm["deepsleep"] = DeepSleep;
m_mappm["off"] = Off;
m_mappm["devel"] = Devel;
powercmd = MyCommandApp.RegisterCommand("power","Power control",NULL,"$C $G$");
}
pcpapp::~pcpapp()
{
}
void pcpapp::Register(const char* name, pcp* device)
{
m_map[name] = device;
OvmsCommand* devcmd = powercmd->RegisterCommand(name,"Power control");
for (auto it=m_mappm.begin(); it!=m_mappm.end(); ++it)
{
devcmd->RegisterCommand(it->first,"Power control",power_cmd);
}
devcmd->RegisterCommand("status","Power control status",power_status);
}
void pcpapp::Deregister(const char* name)
{
m_map.erase(name);
}
pcp* pcpapp::FindDeviceByName(const char* name)
{
auto iter = m_map.find(name);
if (iter != m_map.end())
{
return iter->second;
}
return NULL;
}
PowerMode pcpapp::FindPowerModeByName(const char* name)
{
auto iter = m_mappm.find(name);
if (iter != m_mappm.end())
{
return iter->second;
}
return PowerMode::Undefined;
}
const char* pcpapp::FindPowerModeByType(PowerMode mode)
{
const char* pmname= NULL;
for (auto it=m_mappm.begin(); it!=m_mappm.end(); ++it)
{
if (it->second == mode)
pmname = it->first;
}
if (pmname == NULL) pmname = "undefined";
return pmname;
}
pcp::pcp(const char* name)
{
m_name = name;
m_powermode = On;
MyPcpApp.Register(name,this);
}
pcp::~pcp()
{
MyPcpApp.Deregister(m_name);
}
void pcp::SetPowerMode(PowerMode powermode)
{
if (m_powermode != powermode)
{
m_powermode = powermode;
const char* pmname = MyPcpApp.FindPowerModeByType(m_powermode);
char event[32] = "power.";
strcat(event,m_name);
strcat(event,".");
strcat(event,pmname);
MyEvents.SignalEvent(event,NULL);
}
}
PowerMode pcp::GetPowerMode()
{
return m_powermode;
}
const char* pcp::GetName()
{
return m_name;
}