00001
00002 #ifndef __BCU_CONSTANT_ADAPTER_HH__
00003 #define __BCU_CONSTANT_ADAPTER_HH__
00004
00014 #include <accdata.hh>
00015 #include <accvector.hh>
00016 #include <accdevexception.hh>
00017
00018
00019
00020 using std::auto_ptr;
00021
00022 namespace DeviceAccess
00023 {
00024 namespace EqModBCU
00025 {
00026
00037 class E_API CONSTANTDataAdapter
00038 {
00039 public:
00040
00041 static auto_ptr<const CONSTANTDataAdapter> createRcvP(const DeviceAccess::AccData& data)
00042 {
00043 if (data.size()>3) {
00044 throw(AccDevException(ODA_MOREDATA,ODA_OK,ACCDEV_ERRORLOCATION));
00045 }
00046 DeviceAccess::AccData& mutual_data = const_cast<DeviceAccess::AccData&>(data);
00047 return auto_ptr<const CONSTANTDataAdapter>(new CONSTANTDataAdapter(mutual_data,0));
00048 }
00049
00050 static auto_ptr<CONSTANTDataAdapter> createSndP(DeviceAccess::AccData& data)
00051 {
00052 data.assign(3,Float32());
00053
00054 auto_ptr<CONSTANTDataAdapter> p(new CONSTANTDataAdapter(data,0));
00055 p->init();
00056 return p;
00057 }
00058
00060 Float32 minVoltage() const {
00061 return (*_ptr)[_offset+0].convert(Float32());
00062 }
00063
00065 void minVoltage(Float32 val) {
00066 (*_ptr)[_offset+0] = val;
00067 }
00068
00070 Float32 maxVoltage() const {
00071 return (*_ptr)[_offset+1].convert(Float32());
00072 }
00073
00075 void maxVoltage(Float32 val) {
00076 (*_ptr)[_offset+1] = val;
00077 }
00078
00080 Float32 nomVoltage() const {
00081 return (*_ptr)[_offset+2].convert(Float32());
00082 }
00083
00085 void nomVoltage(Float32 val) {
00086 (*_ptr)[_offset+2] = val;
00087 }
00088
00089
00091 CONSTANTDataAdapter(DeviceAccess::AccData& data, size_t offset=0) : _ptr(&data), _offset(offset)
00092 {
00093 }
00094
00096 void init() {
00097
00098 }
00099
00100
00101
00102 private:
00103 DeviceAccess::AccData* _ptr;
00104 size_t _offset;
00105 };
00106
00108 typedef CONSTANTDataAdapter ReadCONSTANTDataAdapter;
00109
00111 typedef auto_ptr<ReadCONSTANTDataAdapter> ReadCONSTANTDataP;
00112
00116 }
00117 }
00118
00119 #endif