2020-09-30 16:53:55 +02:00

182 lines
4.1 KiB
C++

/*
*
* NOTES:
*
* REVISIONS:
* ker04DEC92 Initial OS/2 Revision
* pcy26Jan93: Superclassed EepromChoiceSensor w/ EepromSensor
* pcy26Jan93: Handle Dip switch events
* rct15Jun93: Added error code for getAllowedValues()
* cad04Mar94: fix for access problem
* dml13Oct95: fixed assignment in logical expression (needed ==)
* cgm12Apr96: Add destructor with unregister
* inf20Mar97: Loaded error string from resource file
* mholly22Oct98 : recognize ErrITEM_NOT_FOUND as a valid error from
* theConfigManager->Get in the getAllowedValues method
*/
extern "C" {
#include <stdlib.h>
#include <stdio.h>
#include <malloc.h>
#include <string.h>
}
#include "eeprom.h"
#include "cfgmgr.h"
#include "event.h"
#include "device.h"
//Constructor
EepromSensor::EepromSensor(PDevice aParent, PCommController aCommController,
INT aSensorCode, ACCESSTYPE anACCESSTYPE)
: Sensor(aParent,aCommController, aSensorCode, anACCESSTYPE)
{
theCommController->RegisterEvent(EEPROM_CHANGED, this);
}
EepromSensor::~EepromSensor()
{
theCommController->UnregisterEvent(EEPROM_CHANGED, this);
}
INT EepromSensor::Update(PEvent anEvent)
{
INT val;
switch(anEvent->GetCode()) {
case EEPROM_CHANGED:
//
//
DeepGet();
break;
case DIP_SWITCH_POSITION:
//
// If the dip swicthes change, reget the valu from the UPS
// and if not all zeros, we cant change the settings so we
// set our access to read only. This probably shouldn't be
// here since it ties UPS implementation to the values of the
// Dip switches. Oh well.
//
DeepGet();
val = (atoi(anEvent->GetValue()) == 0) ? AREAD_WRITE : AREAD_ONLY;
SetEepromAccess(val);
break;
default:
Sensor::Update(anEvent);
break;
}
return ErrNO_ERROR;
}
INT EepromSensor::Set(const PCHAR aValue)
{
return Sensor::Set(aValue);
}
VOID EepromSensor::SetEepromAccess(INT anAccessCode)
{
readOnly = (ACCESSTYPE)anAccessCode;
}
INT EepromSensor::setInitialValue()
{
return ErrNO_ERROR;
}
EepromChoiceSensor:: EepromChoiceSensor(PDevice aParent, PCommController aCommController,
INT aSensorCode, ACCESSTYPE anACCESSTYPE)
:EepromSensor(aParent,aCommController, aSensorCode, anACCESSTYPE)
{
//Set the Values
theAllowedValues = (PCHAR)NULL;
}
EepromChoiceSensor::~EepromChoiceSensor() {
free(theAllowedValues);
}
INT EepromChoiceSensor::Validate(INT aCode, const PCHAR aValue)
{
INT err = ErrNO_ERROR;
if(aCode!=theSensorCode)
err = ErrINVALID_CODE;
if(theAllowedValues != (PCHAR)NULL) {
if(strstr(theAllowedValues, aValue))
err = ErrNO_ERROR;
else
err = ErrINVALID_VALUE;
}
else {
err = ErrINVALID_VALUE;
}
return err;
}
INT EepromChoiceSensor::Get(INT aCode, PCHAR aValue)
{
INT err = ErrNO_ERROR;
switch(aCode)
{
case ALLOWED_VALUES:
getCurrentAllowedValues(aValue);
break;
default:
err = Sensor::Get(aCode, aValue);
break;
}
return err;
}
INT EepromChoiceSensor::getAllowedValues()
{
CHAR value[128];
CHAR allowedValue[128] = "";
INT cCode = _theConfigManager->GetListValue(lookupSensorName(IsA()),
"AllowedValues", value);
theDevice->GetAllowedValue(theSensorCode, allowedValue);
if (strlen(allowedValue))
{
theAllowedValues = _strdup(allowedValue);
return ErrNO_ERROR;
}
else
{
theAllowedValues = _strdup(value);
return cCode;
}
}
VOID EepromChoiceSensor::getCurrentAllowedValues(PCHAR aValue)
{
if (theAllowedValues)
{
strcpy(aValue, theAllowedValues);
}
else
{
strcpy(aValue, "");
}
}