V4 View Generated Code
From EPICSWIKI
Revision as of 04:37, 13 July 2005 by AndrewJohnson (talk | contribs) (First attempt, based on old DataAccess interfaces)
This page shows the code that will be generated from a Record View.
Each view maps to a separate property catalog that gives access to a particular set of fields of the record as a hierarchy. Taking as a simple example the following record definition:
record(rdouble) extends iocRecord { field(value, float64) field(units, string) view(value) { property(value, value) { property(units, units) property(timestamp, timeStamp) property(alarmSeverity, alarmSeverity) property(alarmStatus, alarmStatus) } } }
This very simple record type defines a single value view with 5 properties, of which 4 are subordinate to the main value property. The following code would be generated from the above DBD definition to implement the view as a property catalog for use by the Data Access interface to the CA Server:
class rdouble_view_value_value : public propertyCatalog { public: rdouble_view_value_value(rdoubleRecord &record); void traverse(dataViewer &); // this isn't exactly Jeff's interface, but it shows the idea private: rdoubleRecord &r; };
rdouble_view_value_value::rdouble_view_value_value(rdoubleRecord &r_in) : r(r_in) {}
void rdouble_cat_value_value::traverse(dataViewer & v) { v.reveal(pidUnits, r.units); v.reveal(pidTimestamp, r.timestamp); v.reveal(pidAlarmSeverity, r.alarmSeverity); v.reveal(pidAlarmStatus, r.alarmStatus); }
class rdouble_view_value : public propertyCatalog { public: rdouble_view_value(rdoubleRecord &record); void traverse(dataViewer &); // this isn't exactly Jeff's interface, but it shows the idea private: rdoubleRecord &r; rdouble_view_value_value view_value_value; };
rdouble_view_value::rdouble_view_value(rdoubleRecord &r_in) : r(r_in), view_value_value(r_in) {}
void rdouble_cat_value::traverse(dataViewer & v) { v.reveal(pidValue, r.value, view_value_value); }