235 lines
5.6 KiB
C++
235 lines
5.6 KiB
C++
/* ntcontinuum.cpp */
|
|
/**
|
|
* Copyright - See the COPYRIGHT that is included with this distribution.
|
|
* This software is distributed subject to a Software License Agreement found
|
|
* in file LICENSE that is included with this distribution.
|
|
*/
|
|
|
|
#define epicsExportSharedSymbols
|
|
#include <pv/ntcontinuum.h>
|
|
#include <pv/ntutils.h>
|
|
|
|
using namespace std;
|
|
using namespace epics::pvData;
|
|
|
|
namespace epics { namespace nt {
|
|
|
|
static NTFieldPtr ntField = NTField::get();
|
|
|
|
namespace detail {
|
|
|
|
StructureConstPtr NTContinuumBuilder::createStructure()
|
|
{
|
|
FieldBuilderPtr builder =
|
|
getFieldCreate()->createFieldBuilder()->
|
|
setId(NTContinuum::URI)->
|
|
addArray("base", pvDouble)->
|
|
addArray("value", pvDouble)->
|
|
addArray("units", pvString);
|
|
|
|
if (descriptor)
|
|
builder->add("descriptor", pvString);
|
|
|
|
if (alarm)
|
|
builder->add("alarm", ntField->createAlarm());
|
|
|
|
if (timeStamp)
|
|
builder->add("timeStamp", ntField->createTimeStamp());
|
|
|
|
size_t extraCount = extraFieldNames.size();
|
|
for (size_t i = 0; i< extraCount; i++)
|
|
builder->add(extraFieldNames[i], extraFields[i]);
|
|
|
|
|
|
StructureConstPtr s = builder->createStructure();
|
|
|
|
reset();
|
|
return s;
|
|
}
|
|
|
|
NTContinuumBuilder::shared_pointer NTContinuumBuilder::addDescriptor()
|
|
{
|
|
descriptor = true;
|
|
return shared_from_this();
|
|
}
|
|
|
|
NTContinuumBuilder::shared_pointer NTContinuumBuilder::addAlarm()
|
|
{
|
|
alarm = true;
|
|
return shared_from_this();
|
|
}
|
|
|
|
NTContinuumBuilder::shared_pointer NTContinuumBuilder::addTimeStamp()
|
|
{
|
|
timeStamp = true;
|
|
return shared_from_this();
|
|
}
|
|
|
|
|
|
PVStructurePtr NTContinuumBuilder::createPVStructure()
|
|
{
|
|
return getPVDataCreate()->createPVStructure(createStructure());
|
|
}
|
|
|
|
NTContinuumPtr NTContinuumBuilder::create()
|
|
{
|
|
return NTContinuumPtr(new NTContinuum(createPVStructure()));
|
|
}
|
|
|
|
NTContinuumBuilder::NTContinuumBuilder()
|
|
{
|
|
reset();
|
|
}
|
|
|
|
void NTContinuumBuilder::reset()
|
|
{
|
|
descriptor = false;
|
|
alarm = false;
|
|
timeStamp = false;
|
|
extraFieldNames.clear();
|
|
extraFields.clear();
|
|
}
|
|
|
|
NTContinuumBuilder::shared_pointer NTContinuumBuilder::add(string const & name, FieldConstPtr const & field)
|
|
{
|
|
extraFields.push_back(field); extraFieldNames.push_back(name);
|
|
return shared_from_this();
|
|
}
|
|
|
|
}
|
|
|
|
const std::string NTContinuum::URI("epics:nt/NTContinuum:1.0");
|
|
|
|
NTContinuum::shared_pointer NTContinuum::wrap(PVStructurePtr const & pvStructure)
|
|
{
|
|
if(!isCompatible(pvStructure)) return shared_pointer();
|
|
return wrapUnsafe(pvStructure);
|
|
}
|
|
|
|
NTContinuum::shared_pointer NTContinuum::wrapUnsafe(PVStructurePtr const & pvStructure)
|
|
{
|
|
return shared_pointer(new NTContinuum(pvStructure));
|
|
}
|
|
|
|
bool NTContinuum::is_a(StructureConstPtr const & structure)
|
|
{
|
|
return NTUtils::is_a(structure->getID(), URI);
|
|
}
|
|
|
|
bool NTContinuum::isCompatible(StructureConstPtr const & structure)
|
|
{
|
|
if (structure.get() == 0) return false;
|
|
|
|
ScalarArrayConstPtr baseField = structure->getField<ScalarArray>("base");
|
|
if (baseField.get() == 0 || baseField->getElementType() != pvDouble)
|
|
return false;
|
|
|
|
ScalarArrayConstPtr valueField = structure->getField<ScalarArray>("value");
|
|
if (valueField.get() == 0 || valueField->getElementType() != pvDouble)
|
|
return false;
|
|
|
|
ScalarArrayConstPtr unitsField = structure->getField<ScalarArray>("units");
|
|
if (unitsField.get() == 0 || unitsField->getElementType() != pvString)
|
|
return false;
|
|
|
|
FieldConstPtr field = structure->getField("descriptor");
|
|
if (field.get())
|
|
{
|
|
ScalarConstPtr descriptorField = structure->getField<Scalar>("descriptor");
|
|
if (!descriptorField.get() || descriptorField->getScalarType() != pvString)
|
|
return false;
|
|
}
|
|
|
|
NTFieldPtr ntField = NTField::get();
|
|
|
|
field = structure->getField("alarm");
|
|
if (field.get() && !ntField->isAlarm(field))
|
|
return false;
|
|
|
|
field = structure->getField("timeStamp");
|
|
if (field.get() && !ntField->isTimeStamp(field))
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
bool NTContinuum::isCompatible(PVStructurePtr const & pvStructure)
|
|
{
|
|
if(!pvStructure) return false;
|
|
|
|
return isCompatible(pvStructure->getStructure());
|
|
}
|
|
|
|
bool NTContinuum::isValid()
|
|
{
|
|
return ((getUnits()->getLength()-1)*getBase()->getLength() ==
|
|
getValue()->getLength());
|
|
}
|
|
|
|
NTContinuumBuilderPtr NTContinuum::createBuilder()
|
|
{
|
|
return NTContinuumBuilderPtr(new detail::NTContinuumBuilder());
|
|
}
|
|
|
|
bool NTContinuum::attachTimeStamp(PVTimeStamp &pvTimeStamp) const
|
|
{
|
|
PVStructurePtr ts = getTimeStamp();
|
|
if (ts)
|
|
return pvTimeStamp.attach(ts);
|
|
else
|
|
return false;
|
|
}
|
|
|
|
bool NTContinuum::attachAlarm(PVAlarm &pvAlarm) const
|
|
{
|
|
PVStructurePtr al = getAlarm();
|
|
if (al)
|
|
return pvAlarm.attach(al);
|
|
else
|
|
return false;
|
|
}
|
|
|
|
PVStructurePtr NTContinuum::getPVStructure() const
|
|
{
|
|
return pvNTContinuum;
|
|
}
|
|
|
|
PVStringPtr NTContinuum::getDescriptor() const
|
|
{
|
|
return pvNTContinuum->getSubField<PVString>("descriptor");
|
|
}
|
|
|
|
PVStructurePtr NTContinuum::getTimeStamp() const
|
|
{
|
|
return pvNTContinuum->getSubField<PVStructure>("timeStamp");
|
|
}
|
|
|
|
PVStructurePtr NTContinuum::getAlarm() const
|
|
{
|
|
return pvNTContinuum->getSubField<PVStructure>("alarm");
|
|
}
|
|
|
|
PVDoubleArrayPtr NTContinuum::getBase() const
|
|
{
|
|
return pvNTContinuum->getSubField<PVDoubleArray>("base");
|
|
}
|
|
|
|
PVDoubleArrayPtr NTContinuum::getValue() const
|
|
{
|
|
return pvValue;
|
|
}
|
|
|
|
PVStringArrayPtr NTContinuum::getUnits() const
|
|
{
|
|
return pvNTContinuum->getSubField<PVStringArray>("units");
|
|
}
|
|
|
|
NTContinuum::NTContinuum(PVStructurePtr const & pvStructure) :
|
|
pvNTContinuum(pvStructure),
|
|
pvValue(pvNTContinuum->getSubField<PVDoubleArray>("value"))
|
|
{}
|
|
|
|
|
|
}}
|