pub struct SecPastEpochDeviceSupport;Expand description
“Sec Past Epoch” device support for ai records.
Reads the current time as seconds past the EPICS epoch (1990-01-01). If PHAS field is nonzero, includes fractional seconds.
Ported from devTimeOfDay.c (devAiTodSeconds).
Implementations§
Trait Implementations§
Source§impl Default for SecPastEpochDeviceSupport
impl Default for SecPastEpochDeviceSupport
Source§impl DeviceSupport for SecPastEpochDeviceSupport
impl DeviceSupport for SecPastEpochDeviceSupport
fn dtyp(&self) -> &str
Source§fn read(&mut self, record: &mut dyn Record) -> CaResult<DeviceReadOutcome>
fn read(&mut self, record: &mut dyn Record) -> CaResult<DeviceReadOutcome>
Read from hardware into the record. Read more
fn write(&mut self, _record: &mut dyn Record) -> CaResult<()>
fn init(&mut self, _record: &mut (dyn Record + 'static)) -> Result<(), CaError>
Source§fn last_alarm(&self) -> Option<(u16, u16)>
fn last_alarm(&self) -> Option<(u16, u16)>
Return the last alarm (status, severity) from the driver.
None means the driver does not override alarms.
Source§fn last_timestamp(&self) -> Option<SystemTime>
fn last_timestamp(&self) -> Option<SystemTime>
Return the last timestamp from the driver.
None means the driver does not override timestamps.
Source§fn set_record_info(&mut self, _name: &str, _scan: ScanType)
fn set_record_info(&mut self, _name: &str, _scan: ScanType)
Called after init() with the record name and scan type.
Source§fn io_intr_receiver(&mut self) -> Option<Receiver<()>>
fn io_intr_receiver(&mut self) -> Option<Receiver<()>>
Return a receiver for I/O Intr scan notifications.
Only called for records with SCAN=I/O Intr.
Source§fn write_begin(
&mut self,
_record: &mut (dyn Record + 'static),
) -> Result<Option<Box<dyn WriteCompletion>>, CaError>
fn write_begin( &mut self, _record: &mut (dyn Record + 'static), ) -> Result<Option<Box<dyn WriteCompletion>>, CaError>
Begin an asynchronous write (submit only, no blocking).
Returns
Some(handle) if the write was submitted to a worker queue —
the caller should wait on the handle outside any record lock.
Returns None to fall back to synchronous write().Source§fn handle_command(
&mut self,
_record: &mut (dyn Record + 'static),
_command: &str,
_args: &[EpicsValue],
) -> Result<(), CaError>
fn handle_command( &mut self, _record: &mut (dyn Record + 'static), _command: &str, _args: &[EpicsValue], ) -> Result<(), CaError>
Handle a named command from the record’s process() via
ProcessAction::DeviceCommand. This allows records to request
driver operations (e.g., scaler reset/arm/write_preset) without
holding a direct driver reference. Read moreAuto Trait Implementations§
impl Freeze for SecPastEpochDeviceSupport
impl RefUnwindSafe for SecPastEpochDeviceSupport
impl Send for SecPastEpochDeviceSupport
impl Sync for SecPastEpochDeviceSupport
impl Unpin for SecPastEpochDeviceSupport
impl UnsafeUnpin for SecPastEpochDeviceSupport
impl UnwindSafe for SecPastEpochDeviceSupport
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more