Add SharedPV
This commit is contained in:
142
src/server/sharedstate_put.cpp
Normal file
142
src/server/sharedstate_put.cpp
Normal file
@@ -0,0 +1,142 @@
|
||||
/*
|
||||
* Copyright information and license terms for this software can be
|
||||
* found in the file LICENSE that is included with the distribution
|
||||
*/
|
||||
|
||||
#include <list>
|
||||
|
||||
#include <epicsMutex.h>
|
||||
#include <epicsGuard.h>
|
||||
|
||||
#include <shareLib.h>
|
||||
#include <pv/sharedPtr.h>
|
||||
#include <pv/noDefaultMethods.h>
|
||||
|
||||
#define epicsExportSharedSymbols
|
||||
#include "sharedstateimpl.h"
|
||||
|
||||
namespace {
|
||||
struct PutOP : public pvas::Operation::Impl
|
||||
{
|
||||
const std::tr1::shared_ptr<pvas::SharedPut> op;
|
||||
|
||||
PutOP(const std::tr1::shared_ptr<pvas::SharedPut>& op,
|
||||
const pvd::PVStructure::const_shared_pointer& pvRequest,
|
||||
const pvd::PVStructure::const_shared_pointer& value,
|
||||
const pvd::BitSet& changed)
|
||||
:Impl(pvRequest, value, changed)
|
||||
,op(op)
|
||||
{}
|
||||
virtual ~PutOP() {}
|
||||
|
||||
virtual pva::Channel::shared_pointer getChannel() OVERRIDE FINAL
|
||||
{
|
||||
return op->channel;
|
||||
}
|
||||
|
||||
virtual pva::ChannelBaseRequester::shared_pointer getRequester() OVERRIDE FINAL
|
||||
{
|
||||
return op->requester.lock();
|
||||
}
|
||||
|
||||
virtual void complete(const pvd::Status& sts,
|
||||
const epics::pvData::PVStructure* value) OVERRIDE FINAL
|
||||
{
|
||||
if(value)
|
||||
throw std::logic_error("Put can't complete() with data");
|
||||
|
||||
{
|
||||
Guard G(mutex);
|
||||
if(done)
|
||||
throw std::logic_error("Operation already complete");
|
||||
done = true;
|
||||
}
|
||||
|
||||
pva::ChannelPutRequester::shared_pointer req(op->requester.lock());
|
||||
if(req)
|
||||
req->putDone(sts, op);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
namespace pvas {
|
||||
|
||||
size_t SharedPut::num_instances;
|
||||
|
||||
SharedPut::SharedPut(const std::tr1::shared_ptr<SharedChannel>& channel,
|
||||
const requester_type::shared_pointer& requester,
|
||||
const pvd::PVStructure::const_shared_pointer &pvRequest)
|
||||
:channel(channel)
|
||||
,requester(requester)
|
||||
,pvRequest(pvRequest)
|
||||
{
|
||||
REFTRACE_INCREMENT(num_instances);
|
||||
}
|
||||
|
||||
SharedPut::~SharedPut()
|
||||
{
|
||||
Guard G(channel->owner->mutex);
|
||||
channel->owner->puts.remove(this);
|
||||
REFTRACE_DECREMENT(num_instances);
|
||||
}
|
||||
|
||||
void SharedPut::destroy() {}
|
||||
|
||||
std::tr1::shared_ptr<pva::Channel> SharedPut::getChannel()
|
||||
{
|
||||
return channel;
|
||||
}
|
||||
|
||||
void SharedPut::cancel() {}
|
||||
|
||||
void SharedPut::lastRequest() {}
|
||||
|
||||
void SharedPut::put(
|
||||
pvd::PVStructure::shared_pointer const & pvPutStructure,
|
||||
pvd::BitSet::shared_pointer const & putBitSet)
|
||||
{
|
||||
std::tr1::shared_ptr<SharedPV::Handler> handler;
|
||||
{
|
||||
Guard G(channel->owner->mutex);
|
||||
handler = channel->owner->handler;
|
||||
}
|
||||
|
||||
std::tr1::shared_ptr<PutOP> impl(new PutOP(shared_from_this(), pvRequest, pvPutStructure, *putBitSet),
|
||||
Operation::Impl::Cleanup());
|
||||
|
||||
if(handler) {
|
||||
Operation op(impl);
|
||||
handler->onPut(channel->owner, op);
|
||||
}
|
||||
}
|
||||
|
||||
void SharedPut::get()
|
||||
{
|
||||
|
||||
pvd::Status sts;
|
||||
pvd::PVStructurePtr current;
|
||||
pvd::BitSetPtr changed;
|
||||
{
|
||||
Guard G(channel->owner->mutex);
|
||||
|
||||
if(channel->owner->current) {
|
||||
// clone
|
||||
current = pvd::getPVDataCreate()->createPVStructure(channel->owner->current->getStructure());
|
||||
current->copyUnchecked(*channel->owner->current);
|
||||
|
||||
changed.reset(new pvd::BitSet(channel->owner->valid));
|
||||
}
|
||||
}
|
||||
|
||||
requester_type::shared_pointer req(requester.lock());
|
||||
if(!req) return;
|
||||
|
||||
if(!current) {
|
||||
sts = pvd::Status::error("Get not possible, cache disabled");
|
||||
}
|
||||
|
||||
req->getDone(sts, shared_from_this(), current, changed);
|
||||
}
|
||||
|
||||
} // namespace pvas
|
||||
Reference in New Issue
Block a user