API
 
Loading...
Searching...
No Matches
MagAOX::app::ocam2KCtrl Class Reference

#include <ocam2KCtrl.hpp>

Inheritance diagram for MagAOX::app::ocam2KCtrl:
Inheritance graph
Collaboration diagram for MagAOX::app::ocam2KCtrl:
Collaboration graph

Public Types

typedef XWC_DEFAULT_VERBOSITY verboseT
 
typedef logger::logManager< MagAOXApp< _useINDI >, logFileRaw< verboseT > > logManagerT
 The log manager type.
 
enum  fgFlip
 
typedef int32_t cbIndexT
 
typedef XWC_DEFAULT_VERBOSITY verboseT
 
typedef logger::logManager< ocam2KCtrl, logFileRaw< verboseT > > logManagerT
 The log manager type.
 

Public Member Functions

 ocam2KCtrl ()
 Default c'tor.
 
 ~ocam2KCtrl () noexcept
 Destructor.
 
virtual void setupConfig ()
 Setup the configuration system (called by MagAOXApp::setup())
 
virtual void loadConfig ()
 load the configuration system results (called by MagAOXApp::setup())
 
virtual int appStartup ()
 Startup functions.
 
virtual int appLogic ()
 Implementation of the FSM for the OCAM 2K.
 
virtual int onPowerOff ()
 Implementation of the on-power-off FSM logic.
 
virtual int whilePowerOff ()
 Implementation of the while-powered-off FSM.
 
virtual int appShutdown ()
 Do any needed shutdown tasks.
 
int getTemps ()
 Get the current device temperatures.
 
int getFPS ()
 Get the current frame rate.
 
int resetEMProtection ()
 Reset the EM Protection.
 
int getEMGain ()
 Get the current EM Gain.
 
int setEMGain ()
 Set the EM gain.
 
int configureAcquisition ()
 Implementation of the framegrabber configureAcquisition interface.
 
float fps ()
 Implementation of the frameGrabber fps interface.
 
int startAcquisition ()
 Implementation of the framegrabber startAcquisition interface.
 
int acquireAndCheckValid ()
 Implementation of the framegrabber acquireAndCheckValid interface.
 
int loadImageIntoStream (void *dest)
 Implementation of the framegrabber loadImageIntoStream interface.
 
int reconfig ()
 Implementation of the framegrabber reconfig interface.
 
 INDI_NEWCALLBACK_DECL (ocam2KCtrl, m_indiP_emProtReset)
 
 INDI_SETCALLBACK_DECL (ocam2KCtrl, m_indiP_syncFreq)
 
virtual void setDefaults (int argc, char **argv)
 Set the paths for config files.
 
virtual void setupBasicConfig ()
 The basic MagAO-X configuration setup method. Should not normally be overridden.
 
virtual void loadBasicConfig ()
 The basic MagAO-X configuration processing method. Should not normally be overridden.
 
virtual void checkConfig ()
 Check for unused and unrecognized config options and settings.
 
virtual int execute ()
 The execute method implementing the standard main loop. Should not normally be overridden.
 
int setupConfig (mx::app::appConfigurator &config)
 Setup the configuration system.
 
int loadConfig (mx::app::appConfigurator &config)
 load the configuration system results
 
int pdvSerialWriteRead (std::string &response, const std::string &command)
 Send a serial command over cameralink and retrieve the response.
 
int pdvConfig (std::string &cfgname)
 Configure the EDT framegrabber.
 
void setupConfig (mx::app::appConfigurator &config)
 Setup the configuration system.
 
void loadConfig (mx::app::appConfigurator &config)
 load the configuration system results
 
int pdvStartAcquisition ()
 
int pdvAcquire (timespec &currImageTimestamp)
 
int pdvReconfig ()
 
int setupConfig (mx::app::appConfigurator &config)
 Setup the configuration system.
 
int loadConfig (mx::app::appConfigurator &config)
 load the configuration system results
 
int configCircBuffs ()
 
void setupConfig (mx::app::appConfigurator &config)
 Setup the configuration system.
 
void loadConfig (mx::app::appConfigurator &config)
 load the configuration system results
 
int setShutterState (int sh)
 Change shutter state.
 
int open ()
 Open the shutter.
 
int shut ()
 Shut the shutter.
 
int telem (const typename telT::messageT &msg)
 Make a telemetry recording.
 
int setupConfig (appConfigurator &config)
 Setup an application configurator for the device section.
 
int loadConfig (appConfigurator &config)
 Load the device section from an application configurator.
 
int checkRecordTimes (const telT &tel, telTs... tels)
 Check the time of the last record for each telemetry type and make an entry if needed.
 
int checkRecordTimes (timespec &ts, const telT &tel, telTs... tels)
 Worker function to actually perform the record time checking logic.
 
int checkRecordTimes (timespec &ts)
 Empty function called at the end of the template list.
 
stdCamera Interface
int powerOnDefaults ()
 Set defaults for a power on state.
 
int setTempControl ()
 Turn temperature control on or off.
 
int setTempSetPt ()
 Set the CCD temperature setpoint [stdCamera interface].
 
int setFPS ()
 Set the frame rate. [stdCamera interface].
 
int setSynchro ()
 Set the synchro state. [stdCamera interface].
 
int setExpTime ()
 Required by stdCamera, but this does not do anything for this camera [stdCamera interface].
 
int setNextROI ()
 Required by stdCamera, but this does not do anything for this camera [stdCamera interface].
 
int setShutter (int sh)
 Sets the shutter state, via call to dssShutter::setShutterState(int) [stdCamera interface].
 
std::string stateString ()
 
bool stateStringValid ()
 
Telemeter Interface
int checkRecordTimes ()
 
int recordTelem (const ocam_temps *)
 
int recordTelem (const telem_stdcam *)
 
int recordTelem (const telem_fgtimings *)
 
int recordTemps (bool force=false)
 
Threads
template<class thisPtr , class Function >
int threadStart (std::thread &thrd, bool &thrdInit, pid_t &tpid, pcf::IndiProperty &thProp, int thrdPrio, const std::string &cpuset, const std::string &thrdName, thisPtr *thrdThis, Function &&thrdStart)
 Start a thread, using this class's privileges to set priority, etc.
 
Member Accessors
std::string basePath ()
 Get the.
 
std::string configName ()
 Get the config name.
 
std::string configDir ()
 Get the config directory.
 
std::string configBase ()
 Get the config base file.
 
std::string calibDir ()
 Get the calibration directory.
 
std::string sysPath ()
 Get the system path.
 
std::string secretsPath ()
 Get the secrets path.
 
std::string cpusetPath ()
 Get the cpuset path.
 
unsigned long loopPause ()
 Get the loop pause time.
 
int shutdown ()
 Get the value of the shutdown flag.
 
std::string driverInName ()
 Get the INDI input FIFO file name.
 
std::string driverOutName ()
 Get the INDI output FIFO file name.
 
std::string driverCtrlName ()
 Get the INDI control FIFO file name.
 
Telemeter Interface
int recordCamera (bool force=false)
 
INDI
int updateINDI ()
 The static callback function to be registered for the channel properties.
 
Telemeter Interface
int recordFGTimings (bool force=false)
 

Public Attributes

unsigned m_readTimeout {1000}
 The read timeout [msec].
 
unsigned m_writeTimeout {1000}
 The write timeout [msec].
 
logManagerT m_tel
 
double m_maxInterval
 The maximum interval, in seconds, between telemetry records. Default is 10.0 seconds.
 

Static Public Attributes

app::dev Configurations
static constexpr bool c_stdCamera_tempControl = true
 app::dev config to tell stdCamera to expose temperature controls
 
static constexpr bool c_stdCamera_temp = true
 app::dev config to tell stdCamera to expose temperature (ignored since tempControl==true)
 
static constexpr bool c_stdCamera_readoutSpeed = false
 app::dev config to tell stdCamera not to expose readout speed controls
 
static constexpr bool c_stdCamera_vShiftSpeed = false
 app:dev config to tell stdCamera not to expose vertical shift speed control
 
static constexpr bool c_stdCamera_emGain = true
 app::dev config to tell stdCamera to expose EM gain controls
 
static constexpr bool c_stdCamera_exptimeCtrl = false
 app::dev config to tell stdCamera not to expose exposure time controls
 
static constexpr bool c_stdCamera_fpsCtrl = true
 app::dev config to tell stdCamera to expose FPS controls
 
static constexpr bool c_stdCamera_fps = true
 app::dev config to tell stdCamera not to expose FPS status (ignored since fpsCtrl==true)
 
static constexpr bool c_stdCamera_synchro = true
 app::dev config to tell stdCamera to expose synchro mode controls
 
static constexpr bool c_stdCamera_usesModes = true
 app:dev config to tell stdCamera not to expose mode controls
 
static constexpr bool c_stdCamera_usesROI = false
 app:dev config to tell stdCamera to expose ROI controls
 
static constexpr bool c_stdCamera_cropMode = false
 app:dev config to tell stdCamera to expose Crop Mode controls
 
static constexpr bool c_stdCamera_hasShutter = true
 app:dev config to tell stdCamera to expose shutter controls
 
static constexpr bool c_stdCamera_usesStateString = true
 app::dev confg to tell stdCamera to expose the state string property
 
static constexpr bool c_edtCamera_relativeConfigPath = true
 app::dev config to tell edtCamera to use relative path to camera config file
 
static constexpr bool c_frameGrabber_flippable = false
 app:dev config to tell framegrabber these images can not be flipped
 

Protected Member Functions

int createReadoutSpeed (const mx::meta::trueFalseT< true > &t)
 
int createReadoutSpeed (const mx::meta::trueFalseT< false > &f)
 
int createVShiftSpeed (const mx::meta::trueFalseT< true > &t)
 
int createVShiftSpeed (const mx::meta::trueFalseT< false > &f)
 
voidloadImageIntoStreamCopy (void *dest, void *src, size_t width, size_t height, size_t szof)
 

Protected Attributes

ocam2_id m_ocam2_id {0}
 OCAM SDK id.
 
long m_currImageNumber {-1}
 The current image number, retrieved from the image itself.
 
long m_lastImageNumber {-1}
 The last image number, saved from the last loop through.
 
bool m_protectionReset {false}
 Flag indicating that protection has been reset at least once.
 
unsigned m_protectionResetConfirmed {0}
 Counter indicating the number of times that the protection reset has been requested within 10 seconds, for confirmation.
 
double m_protectionResetReqTime {0}
 The time at which protection reset was requested. You have 10 seconds to confirm.
 
bool m_poweredOn {false}
 
ocamTemps m_temps
 Structure holding the last temperature measurement.
 
unsigned m_digitalBinX {1}
 
unsigned m_digitalBinY {1}
 
bool m_digitalBin {false}
 
mx::improc::eigenImage< int16_tm_digitalBinWork
 
std::string m_syncDevice {"fxngensync"}
 
std::string m_syncFreqProp {"C1freq"}
 
float m_syncFreq {0}
 
pcf::IndiProperty m_indiP_temps
 
pcf::IndiProperty m_indiP_emProt
 
pcf::IndiProperty m_indiP_emProtReset
 
pcf::IndiProperty m_indiP_syncFreq
 
std::string m_basePath
 The base path of the MagAO-X system.
 
std::string m_configName
 The name of the configuration file (minus .conf).
 
std::string m_configDir
 The path to configuration files for MagAOX.
 
std::string m_configBase
 The name of a base config class for this app (minus .conf).
 
std::string m_calibDir
 The path to calibration files for MagAOX.
 
std::string m_sysPath
 The path to the system directory, for PID file, etc.
 
std::string m_secretsPath
 Path to the secrets directory, where passwords, etc, are stored.
 
std::string m_cpusetPath { MAGAOX_cpusetPath }
 Path to the cpusets mount.
 
unsigned long m_loopPause { MAGAOX_default_loopPause }
 
int m_shutdown { 0 }
 Flag to signal it's time to shutdown. When not 0, the main loop exits.
 
PdvDevm_pdv
 The EDT PDV device handle.
 
u_charm_image_p
 The image data grabbed.
 
int m_raw_height
 The height of the frame, according to the framegrabber.
 
int m_raw_width
 The width of the frame, according to the framegrabber.
 
int m_raw_depth
 The bit-depth of the frame, according to the framegrabber.
 
std::string m_cameraType
 The camera type according to the framegrabber.
 
uint32_t m_width
 The width of the image, once deinterlaced etc.
 
uint32_t m_height
 The height of the image, once deinterlaced etc.
 
uint8_t m_dataType
 The ImageStreamIO type code.
 
size_t m_typeSize
 The size of the type, in bytes. Result of sizeof.
 
int m_xbinning
 The x-binning according to the framegrabber.
 
int m_ybinning
 The y-binning according to the framegrabber.
 
timespec m_currImageTimestamp
 The timestamp of the current image.
 
bool m_reconfig
 Flag to set if a camera reconfiguration requires a framegrabber reset.
 
IMAGEm_imageStream
 The ImageStreamIO shared memory buffer.
 
float m_cbFPS
 The FPS used to configure the circular buffers.
 
mx::sigproc::circularBufferIndex< timespec, cbIndexTm_atimes
 
mx::sigproc::circularBufferIndex< timespec, cbIndexTm_wtimes
 
std::vector< doublem_atimesD
 
std::vector< doublem_wtimesD
 
std::vector< doublem_watimesD
 
timespec m_dummy_ts
 
uint64_t m_dummy_cnt
 
char m_dummy_c
 
double m_mna
 
double m_vara
 
double m_mina
 
double m_maxa
 
double m_mnw
 
double m_varw
 
double m_minw
 
double m_maxw
 
double m_mnwa
 
double m_varwa
 
int m_powerState
 The current power state, -1 is unknown, 0 is off, 1 is on.
 
int m_sensorState
 The current sensor state, -1 is unknown, 0 is shut, 1 is open.
 
int m_triggerState
 The current trigger state. -1 is unknown, 0 is low, 1 is high.
 
configurable parameters
std::string m_ocamDescrambleFile
 Path the OCAM 2K pixel descrambling file, relative to MagAO-X config directory.
 
Configurable Parameters
cameraConfigMap m_cameraModes
 Map holding the possible camera mode configurations.
 
std::string m_startupMode
 The camera mode to load during first init after a power-on.
 
float m_startupTemp
 The temperature to set after a power-on. Set to <= -999 to not use [default].
 
std::string m_defaultReadoutSpeed
 The default readout speed of the camera.
 
std::string m_defaultVShiftSpeed
 The default readout speed of the camera.
 
Temperature Control Interface
float m_minTemp
 
float m_maxTemp
 
float m_stepTemp
 
float m_ccdTemp
 The current temperature, in C.
 
float m_ccdTempSetpt
 The desired temperature, in C.
 
bool m_tempControlStatus
 Whether or not temperature control is active.
 
bool m_tempControlStatusSet
 Desired state of temperature control.
 
bool m_tempControlOnTarget
 Whether or not the temperature control system is on its target temperature.
 
std::string m_tempControlStatusStr
 Camera specific description of temperature control status.
 
pcf::IndiProperty m_indiP_temp
 
pcf::IndiProperty m_indiP_tempcont
 
pcf::IndiProperty m_indiP_tempstat
 
Readout Control
std::vector< std::string > m_readoutSpeedNames
 
std::vector< std::string > m_readoutSpeedNameLabels
 
std::string m_readoutSpeedName
 The current readout speed name.
 
std::string m_readoutSpeedNameSet
 The user requested readout speed name, to be set by derived()
 
std::vector< std::string > m_vShiftSpeedNames
 
std::vector< std::string > m_vShiftSpeedNameLabels
 
std::string m_vShiftSpeedName
 The current vshift speed name.
 
std::string m_vShiftSpeedNameSet
 The user requested vshift speed name, to be set by derived()
 
float m_adcSpeed
 
float m_vshiftSpeed
 
float m_emGain
 The camera's current EM gain (if available).
 
float m_emGainSet
 The camera's EM gain, as set by the user.
 
float m_maxEMGain
 The configurable maximum EM gain. To be enforced in derivedT.
 
pcf::IndiProperty m_indiP_readoutSpeed
 
pcf::IndiProperty m_indiP_vShiftSpeed
 
pcf::IndiProperty m_indiP_emGain
 
Exposure Control
float m_minExpTime
 The minimum exposure time, used for INDI attributes.
 
float m_maxExpTime
 The maximum exposure time, used for INDI attributes.
 
float m_stepExpTime
 The maximum exposure time stepsize, used for INDI attributes.
 
float m_expTime
 The current exposure time, in seconds.
 
float m_expTimeSet
 The exposure time, in seconds, as set by user.
 
float m_minFPS
 The minimum FPS, used for INDI attributes.
 
float m_maxFPS
 The maximum FPS, used for INDI attributes.
 
float m_stepFPS
 The FPS step size, used for INDI attributes.
 
float m_fps
 The current FPS.
 
float m_fpsSet
 The commanded fps, as set by user.
 
pcf::IndiProperty m_indiP_exptime
 
pcf::IndiProperty m_indiP_fps
 
External Synchronization
bool m_synchroSet
 Target status of m_synchro.
 
bool m_synchro
 Status of synchronization, true is on, false is off.
 
pcf::IndiProperty m_indiP_synchro
 
Modes
std::string m_modeName
 The current mode name.
 
std::string m_nextMode
 The mode to be set by the next reconfiguration.
 
pcf::IndiProperty m_indiP_mode
 Property used to report the current mode.
 
pcf::IndiProperty m_indiP_reconfig
 Request switch which forces the framegrabber to go through the reconfigure process.
 
ROIs

ROI controls are exposed if derivedT::c_stdCamera_usesROI==true

roi m_currentROI
 
roi m_nextROI
 
roi m_lastROI
 
float m_minROIx
 
float m_maxROIx
 
float m_stepROIx
 
float m_minROIy
 
float m_maxROIy
 
float m_stepROIy
 
int m_minROIWidth
 
int m_maxROIWidth
 
int m_stepROIWidth
 
int m_minROIHeight
 
int m_maxROIHeight
 
int m_stepROIHeight
 
int m_minROIBinning_x
 
int m_maxROIBinning_x
 
int m_stepROIBinning_x
 
int m_minROIBinning_y
 
int m_maxROIBinning_y
 
int m_stepROIBinning_y
 
float m_default_x
 Power-on ROI center x coordinate.
 
float m_default_y
 Power-on ROI center y coordinate.
 
int m_default_w
 Power-on ROI width.
 
int m_default_h
 Power-on ROI height.
 
int m_default_bin_x
 Power-on ROI x binning.
 
int m_default_bin_y
 Power-on ROI y binning.
 
float m_full_x
 The full ROI center x coordinate.
 
float m_full_y
 The full ROI center y coordinate.
 
int m_full_w
 The full ROI width.
 
int m_full_h
 The full ROI height.
 
int m_full_bin_x
 The x-binning in the full ROI.
 
int m_full_bin_y
 The y-binning in the full ROI.
 
float m_full_currbin_x
 The current-binning full ROI center x coordinate.
 
float m_full_currbin_y
 The current-binning full ROI center y coordinate.
 
int m_full_currbin_w
 The current-binning full ROI width.
 
int m_full_currbin_h
 The current-binning full ROI height.
 
pcf::IndiProperty m_indiP_roi_x
 Property used to set the ROI x center coordinate.
 
pcf::IndiProperty m_indiP_roi_y
 Property used to set the ROI x center coordinate.
 
pcf::IndiProperty m_indiP_roi_w
 Property used to set the ROI width.
 
pcf::IndiProperty m_indiP_roi_h
 Property used to set the ROI height.
 
pcf::IndiProperty m_indiP_roi_bin_x
 Property used to set the ROI x binning.
 
pcf::IndiProperty m_indiP_roi_bin_y
 Property used to set the ROI y binning.
 
pcf::IndiProperty m_indiP_fullROI
 Property used to preset the full ROI dimensions.
 
pcf::IndiProperty m_indiP_roi_check
 Property used to trigger checking the target ROI.
 
pcf::IndiProperty m_indiP_roi_set
 Property used to trigger setting the ROI.
 
pcf::IndiProperty m_indiP_roi_full
 Property used to trigger setting the full ROI.
 
pcf::IndiProperty m_indiP_roi_fullbin
 Property used to trigger setting the full in current binning ROI.
 
pcf::IndiProperty m_indiP_roi_loadlast
 Property used to trigger loading the last ROI as the target.
 
pcf::IndiProperty m_indiP_roi_last
 Property used to trigger setting the last ROI.
 
pcf::IndiProperty m_indiP_roi_default
 Property used to trigger setting the default and startup ROI.
 
Crop Mode

Crop mode controls are exposed if derivedT::c_stdCamera_cropMode==true

bool m_cropMode
 Status of crop mode ROIs, if enabled for this camera.
 
bool m_cropModeSet
 Desired status of crop mode ROIs, if enabled for this camera.
 
pcf::IndiProperty m_indiP_cropMode
 Property used to toggle crop mode on and off.
 
Shutter Control

Shutter controls are exposed if derivedT::c_stdCamera_hasShutter == true.

std::string m_shutterStatus
 
int m_shutterState
 
pcf::IndiProperty m_indiP_shutterStatus
 State of the shutter. 0 = shut, 1 = open, -1 = unknown.
 
pcf::IndiProperty m_indiP_shutter
 Property used to control the shutter, a switch.
 
State String

The State string is exposed if derivedT::c_stdCamera_usesStateString is true.

pcf::IndiProperty m_indiP_stateString
 
Configurable Parameters
int m_unit
 EDT PDV board unit number.
 
int m_channel
 EDT PDV board channel number.
 
int m_numBuffs
 EDT PDV DMA buffer size, indicating number of images.
 
Configurable Parameters
std::string m_shmimName
 
int m_fgThreadPrio
 Priority of the framegrabber thread, should normally be > 00.
 
std::string m_fgCpuset
 The cpuset to assign the framegrabber thread to. Not used if empty, the default.
 
uint32_t m_circBuffLength
 Length of the circular buffer, in frames.
 
cbIndexT m_latencyCircBuffMaxLength
 Maximum length of the latency measurement circular buffers.
 
float m_latencyCircBuffMaxTime
 Maximum time of the latency meaurement circular buffers.
 
int m_defaultFlip
 
Configurable Parameters
std::string m_powerDevice
 The device controlling this shutter's power.
 
std::string m_powerChannel
 The channel controlling this shutter's power.
 
std::string m_dioDevice
 The device controlling this shutter's digital I/O.
 
std::string m_sensorChannel
 The channel reading this shutter's sensor.
 
std::string m_triggerChannel
 The channel sending this shutter's trigger.
 
unsigned m_shutterWait
 The time to pause between checks of the sensor state during open/shut [msec]. Default is 100.
 
unsigned m_shutterTimeout
 Total time to wait for sensor to change state before timing out [msec]. Default is 2000.
 

Private Types

typedef MagAOXApp MagAOXAppT
 

Private Member Functions

int clearFSMAlert ()
 Clear the FSM alert state.
 
ocam2KCtrlderived ()
 

Friends

class dev::stdCamera< ocam2KCtrl >
 
class dev::edtCamera< ocam2KCtrl >
 
class dev::frameGrabber< ocam2KCtrl >
 
class dev::dssShutter< ocam2KCtrl >
 
class dev::telemeter< ocam2KCtrl >
 

Logging

static logManagerT m_log
 
void logMessage (bufferPtrT &b)
 Handle a log message from the logging system.
 
template<typename logT , int retval = 0>
static int log (const typename logT::messageT &msg, logPrioT level=logPrio::LOG_DEFAULT)
 Make a log entry.
 
template<typename logT , int retval = 0>
static int log (logPrioT level=logPrio::LOG_DEFAULT)
 Make a log entry.
 
static void configLog (const std::string &name, const int &code, const std::string &value, const std::string &source)
 Callback for config system logging.
 

PID Locking

Each MagAOXApp has a PID lock file in the system directory. The app will not startup if it detects that the PID is already locked, preventing duplicates. This is based on the configured name, not the invoked name (argv[0]).

std::string pidFileName
 The name of the PID file.
 
pid_t m_pid { 0 }
 This process's PID.
 
int lockPID ()
 
int unlockPID ()
 Remove the PID file.
 

INDI Interface

For reference: "Get" and "New" refer to properties we own. "Set" refers to properties owned by others. So we respond to GetProperties by listing our own properties, and NewProperty is a request to change a property we own. Whereas SetProperty is a notification that someone else has changed a property.

std::unordered_map< std::string, indiCallBackm_indiNewCallBacks
 Map to hold the NewProperty indiCallBacks for this App, with fast lookup by property name.
 
std::unordered_map< std::string, indiCallBackm_indiSetCallBacks
 Map to hold the SetProperty indiCallBacks for this App, with fast lookup by property name.
 
bool m_allDefsReceived { false }
 Flag indicating that all registered Set properties have been updated since last Get.
 
std::string m_driverInName
 Full path name of the INDI driver input FIFO.
 
std::string m_driverOutName
 Full path name of the INDI driver output FIFO.
 
std::string m_driverCtrlName
 Full path name of the INDI driver control FIFO.
 
pcf::IndiProperty m_indiP_state
 indi Property to report the application state.
 
pcf::IndiProperty m_indiP_clearFSMAlert
 indi Property to clear an FSM alert.
 
int createStandardIndiText (pcf::IndiProperty &prop, const std::string &propName, const std::string &label="", const std::string &group="")
 Create a standard R/W INDI Text property with target and current elements.
 
int createROIndiText (pcf::IndiProperty &prop, const std::string &propName, const std::string &elName, const std::string &propLabel="", const std::string &propGroup="", const std::string &elLabel="")
 Create a standard ReadOnly INDI Text property, with at least one element.
 
template<typename T >
int createStandardIndiNumber (pcf::IndiProperty &prop, const std::string &name, const T &min, const T &max, const T &step, const std::string &format, const std::string &label="", const std::string &group="")
 Create a standard R/W INDI Number property with target and current elements.
 
int createROIndiNumber (pcf::IndiProperty &prop, const std::string &propName, const std::string &propLabel="", const std::string &propGroup="")
 Create a ReadOnly INDI Number property.
 
int createStandardIndiToggleSw (pcf::IndiProperty &prop, const std::string &name, const std::string &label="", const std::string &group="")
 Create a standard R/W INDI switch with a single toggle element.
 
int createStandardIndiRequestSw (pcf::IndiProperty &prop, const std::string &name, const std::string &label="", const std::string &group="")
 Create a standard R/W INDI switch with a single request element.
 
int createStandardIndiSelectionSw (pcf::IndiProperty &prop, const std::string &name, const std::vector< std::string > &elements, const std::vector< std::string > &elementLabels, const std::string &label="", const std::string &group="")
 Create a standard R/W INDI selection (one of many) switch with vector of elements and element labels.
 
int createStandardIndiSelectionSw (pcf::IndiProperty &prop, const std::string &name, const std::vector< std::string > &elements, const std::string &label="", const std::string &group="")
 
int registerIndiPropertyReadOnly (pcf::IndiProperty &prop)
 Register an INDI property which is read only.
 
int registerIndiPropertyReadOnly (pcf::IndiProperty &prop, const std::string &propName, const pcf::IndiProperty::Type &propType, const pcf::IndiProperty::PropertyPermType &propPerm, const pcf::IndiProperty::PropertyStateType &propState)
 Register an INDI property which is read only.
 
int registerIndiPropertyNew (pcf::IndiProperty &prop, int(*)(void *, const pcf::IndiProperty &))
 Register an INDI property which is exposed for others to request a New Property for.
 
int registerIndiPropertyNew (pcf::IndiProperty &prop, const std::string &propName, const pcf::IndiProperty::Type &propType, const pcf::IndiProperty::PropertyPermType &propPerm, const pcf::IndiProperty::PropertyStateType &propState, int(*)(void *, const pcf::IndiProperty &))
 Register an INDI property which is exposed for others to request a New Property for.
 
int registerIndiPropertyNew (pcf::IndiProperty &prop, const std::string &propName, const pcf::IndiProperty::Type &propType, const pcf::IndiProperty::PropertyPermType &propPerm, const pcf::IndiProperty::PropertyStateType &propState, const pcf::IndiProperty::SwitchRuleType &propRule, int(*)(void *, const pcf::IndiProperty &))
 Register an INDI property which is exposed for others to request a New Property for, with a switch rule.
 
int registerIndiPropertySet (pcf::IndiProperty &prop, const std::string &devName, const std::string &propName, int(*)(void *, const pcf::IndiProperty &))
 Register an INDI property which is monitored for updates from others.
 
void sendGetPropertySetList (bool all=false)
 
void handleDefProperty (const pcf::IndiProperty &ipRecv)
 Handler for the DEF INDI properties notification.
 
void handleGetProperties (const pcf::IndiProperty &ipRecv)
 Handler for the get INDI properties request.
 
void handleNewProperty (const pcf::IndiProperty &ipRecv)
 Handler for the new INDI property request.
 
void handleSetProperty (const pcf::IndiProperty &ipRecv)
 Handler for the set INDI property request.
 
typedef std::pair< std::string, indiCallBackcallBackValueType
 Value type of the indiCallBack map.
 
typedef std::unordered_map< std::string, indiCallBack >::iterator callBackIterator
 Iterator type of the indiCallBack map.
 
typedef std::pair< callBackIterator, boolcallBackInsertResult
 Return type of insert on the indiCallBack map.
 
static constexpr bool m_useINDI = _useINDI
 Flag controlling whether INDI is used. If false, then no INDI code executes.
 
indiDriver< MagAOXApp > * m_indiDriver { nullptr }
 The INDI driver wrapper. Constructed and initialized by execute, which starts and stops communications.
 
std::mutex m_indiMutex
 Mutex for locking INDI communications.
 
static int st_newCallBack_clearFSMAlert (void *app, const pcf::IndiProperty &ipRecv)
 The static callback function to be registered for requesting to clear the FSM alert.
 
int createINDIFIFOS ()
 Create the INDI FIFOs.
 
int startINDI ()
 Start INDI Communications.
 
template<typename T >
void updateIfChanged (pcf::IndiProperty &p, const std::string &el, const T &newVal, pcf::IndiProperty::PropertyStateType ipState=pcf::IndiProperty::Ok)
 Update an INDI property element value if it has changed.
 
void updateIfChanged (pcf::IndiProperty &p, const std::string &el, const char *newVal, pcf::IndiProperty::PropertyStateType ipState=pcf::IndiProperty::Ok)
 Update an INDI property element value if it has changed.
 
template<typename T >
void updateIfChanged (pcf::IndiProperty &p, const std::string &el, const std::vector< T > &newVals, pcf::IndiProperty::PropertyStateType ipState=pcf::IndiProperty::Ok)
 Update an INDI property if values have changed.
 
template<typename T >
void updateIfChanged (pcf::IndiProperty &p, const std::vector< std::string > &els, const std::vector< T > &newVals, pcf::IndiProperty::PropertyStateType newState=pcf::IndiProperty::Ok)
 Update an INDI property if values have changed.
 
void updateSwitchIfChanged (pcf::IndiProperty &p, const std::string &el, const pcf::IndiElement::SwitchStateType &newVal, pcf::IndiProperty::PropertyStateType ipState=pcf::IndiProperty::Ok)
 Update an INDI switch element value if it has changed.
 
template<typename T >
void updatesIfChanged (pcf::IndiProperty &p, const std::vector< const char * > &els, const std::vector< T > &newVals, pcf::IndiProperty::PropertyStateType newState=pcf::IndiProperty::Ok)
 
template<typename T >
int indiTargetUpdate (pcf::IndiProperty &localProperty, T &localTarget, const pcf::IndiProperty &remoteProperty, bool setBusy=true)
 Get the target element value from an new property.
 
template<typename T >
int sendNewProperty (const pcf::IndiProperty &ipSend, const std::string &el, const T &newVal)
 Send a newProperty command to another device (using the INDI Client interface)
 
int sendNewProperty (const pcf::IndiProperty &ipSend)
 Send a newProperty command to another device (using the INDI Client interface)
 
int sendNewStandardIndiToggle (const std::string &device, const std::string &property, bool onoff)
 Send a new property commmand for a standard toggle switch.
 
int newCallBack_clearFSMAlert (const pcf::IndiProperty &ipRecv)
 The callback called by the static version, to actually process the FSM Alert Clear request.
 

Power Management

For devices which have remote power management (e.g. from one of the PDUs) we implement a standard power state monitoring and management component for the FSM. This needs to be enabled in the derived app constructor. To stay enabled, m_powerDevice and m_powerChannel must be not empty strings after the configuration. These could be set in the derived app defaults.

If power management is enabled, then while power is off, appLogic will not be called. Instead a parrallel set of virtual functions is called, onPowerOff (to allow apps to perform cleanup) and whilePowerOff (to allow apps to keep variables updated, etc). Note that these could merely call appLogic if desired.

bool m_powerMgtEnabled { false }
 
std::string m_powerDevice
 The INDI device name of the power controller.
 
std::string m_powerChannel
 The INDI property name of the channel controlling this device's power.
 
std::string m_powerElement { "state" }
 The INDI element name to monitor for this device's power state.
 
std::string m_powerTargetElement { "target" }
 The INDI element name to monitor for this device's power state.
 
unsigned long m_powerOnWait { 0 }
 Time in sec to wait for device to boot after power on.
 
int m_powerOnCounter { -1 }
 
int m_powerState { -1 }
 Current power state, 1=On, 0=Off, -1=Unk.
 
int m_powerTargetState { -1 }
 Current target power state, 1=On, 0=Off, -1=Unk.
 
pcf::IndiProperty m_indiP_powerChannel
 INDI property used to communicate power state.
 
int powerState ()
 Returns the current power state.
 
int powerStateTarget ()
 Returns the target power state.
 
 INDI_SETCALLBACK_DECL (MagAOXApp, m_indiP_powerChannel)
 
bool powerOnWaitElapsed ()
 This method tests whether the power on wait time has elapsed.
 

Framegrabber Thread

This thread actually manages the framegrabbing hardware

bool m_fgThreadInit
 Synchronizer for thread startup, to allow priority setting to finish.
 
pid_t m_fgThreadID
 The ID of the framegrabber thread.
 
pcf::IndiProperty m_fgThreadProp
 The property to hold the f.g. thread details.
 
std::thread m_fgThread
 A separate thread for the actual framegrabbings.
 
static void fgThreadStart (frameGrabber *o)
 Thread starter, called by MagAOXApp::threadStart on thread construction. Calls fgThreadExec.
 
void fgThreadExec ()
 Execute framegrabbing.
 

INDI

pcf::IndiProperty m_indiP_shmimName
 Property used to report the shmim buffer name.
 
pcf::IndiProperty m_indiP_frameSize
 Property used to report the current frame size.
 
pcf::IndiProperty m_indiP_timing
 
int updateINDI ()
 Update the INDI properties for this device controller.
 

Open/Shut Threads

Separate threads are used since we need INDI updates while trying to open/shut. These threads sleep(1), unless interrupted by a signal. When signaled, they check for the m_doOpen or m_doShut flag, and if true the appropriate open() or shut() function is called. If not, they go back to sleep unless m_shutdown is true.

bool m_doOpen
 Flag telling the open thread that it should actually open the shutter, not just go back to sleep.
 
bool m_openThreadInit
 Initialization flag for the open thread.
 
pid_t m_openThreadID
 Open thread PID.
 
pcf::IndiProperty m_openThreadProp
 The property to hold the open thread details.
 
std::thread m_openThread
 The opening thread.
 
bool m_doShut
 Flag telling the shut thread that it should actually shut the shutter, not just go back to sleep.
 
bool m_shutThreadInit
 Initialization flag for the shut thread.
 
pid_t m_shutThreadID
 Shut thread PID.
 
pcf::IndiProperty m_shutThreadProp
 The property to hold the shut thread details.
 
std::thread m_shutThread
 The shutting thread.
 
static void openThreadStart (dssShutter *d)
 Open thread starter function.
 
static void shutThreadStart (dssShutter *d)
 Shut thread starter function.
 
void openThreadExec ()
 Open thread function.
 
void shutThreadExec ()
 Shut thread function.
 

INDI

pcf::IndiProperty m_indiP_powerChannel
 Property used to monitor the shutter's power state.
 
pcf::IndiProperty m_indiP_sensorChannel
 Property used to monitor the shutter's hall sensor.
 
pcf::IndiProperty m_indiP_triggerChannel
 Property used to monitor and set the shutter's trigger.
 
int setCallBack_powerChannel (const pcf::IndiProperty &ipRecv)
 The callback called by the static version, to actually process the new request.
 
int setCallBack_sensorChannel (const pcf::IndiProperty &ipRecv)
 The callback called by the static version, to actually process the new request.
 
int setCallBack_triggerChannel (const pcf::IndiProperty &ipRecv)
 The callback called by the static version, to actually process the new request.
 
static int st_setCallBack_powerChannel (void *app, const pcf::IndiProperty &ipRecv)
 The static callback function to be registered for shutter power channel changes.
 
static int st_setCallBack_sensorChannel (void *app, const pcf::IndiProperty &ipRecv)
 The static callback function to be registered for shutter sensor channel changes.
 
static int st_setCallBack_triggerChannel (void *app, const pcf::IndiProperty &ipRecv)
 The static callback function to be registered for shutter trigger channel changes.
 

Application State

stateCodes::stateCodeT state ()
 Get the current state code.
 
void state (const stateCodes::stateCodeT &s, bool stateAlert=false)
 Set the current state code.
 
bool stateAlert ()
 Get the value of the state alert flag.
 
bool gitAlert ()
 Get the value of the git alert flag.
 
int stateLogged ()
 Updates and returns the value of m_stateLogged. Will be 0 on first call after a state change, >0 afterwards.
 
stateCodes::stateCodeT m_state { stateCodes::UNINITIALIZED }
 
bool m_stateAlert { false }
 
bool m_gitAlert { false }
 
int m_stateLogged { 0 }
 

INDI

int newCallBack_stdCamera (const pcf::IndiProperty &ipRecv)
 The callback function for stdCamera properties.
 
int setTempSetPt (const mx::meta::trueFalseT< true > &t)
 Interface to setTempSetPt when the derivedT has temperature control.
 
int setTempSetPt (const mx::meta::trueFalseT< false > &f)
 Interface to setTempSetPt when the derivedT does not have temperature control.
 
int newCallBack_temp (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW CCD temp request.
 
int setTempControl (const mx::meta::trueFalseT< true > &t)
 Interface to setTempControl when the derivedT has temperature control.
 
int setTempControl (const mx::meta::trueFalseT< false > &f)
 Interface to setTempControl when the derivedT does not have temperature control.
 
int newCallBack_temp_controller (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW CCD temp control request.
 
int setReadoutSpeed (const mx::meta::trueFalseT< true > &t)
 Interface to setReadoutSpeed when the derivedT has readout speed control.
 
int setReadoutSpeed (const mx::meta::trueFalseT< false > &f)
 Interface to setReadoutSpeed when the derivedT does not have readout speed control.
 
int newCallBack_readoutSpeed (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW readout speed request.
 
int setVShiftSpeed (const mx::meta::trueFalseT< true > &t)
 Interface to setVShiftSpeed when the derivedT has vshift speed control.
 
int setVShiftSpeed (const mx::meta::trueFalseT< false > &f)
 Interface to setVShiftSpeed when the derivedT does not have vshift speed control.
 
int newCallBack_vShiftSpeed (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW vshift speed request.
 
int setEMGain (const mx::meta::trueFalseT< true > &t)
 Interface to setEMGain when the derivedT has EM Gain.
 
int setEMGain (const mx::meta::trueFalseT< false > &f)
 Interface to setEMGain when the derivedT does not have EM Gain.
 
int newCallBack_emgain (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW EM gain request.
 
int setExpTime (const mx::meta::trueFalseT< true > &t)
 Interface to setExpTime when the derivedT uses exposure time controls.
 
int setExpTime (const mx::meta::trueFalseT< false > &f)
 Interface to setExptime when the derivedT does not use exposure time controls.
 
int newCallBack_exptime (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW exposure time request.
 
int setFPS (const mx::meta::trueFalseT< true > &t)
 Interface to setFPS when the derivedT uses FPS controls.
 
int setFPS (const mx::meta::trueFalseT< false > &f)
 Interface to setFPS when the derivedT does not use FPS controls.
 
int newCallBack_fps (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW fps request.
 
int setSynchro (const mx::meta::trueFalseT< true > &t)
 Interface to setSynchro when the derivedT has synchronization.
 
int setSynchro (const mx::meta::trueFalseT< false > &f)
 Interface to setSynchro when the derivedT does not have synchronization.
 
int newCallBack_synchro (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW synchro request.
 
int newCallBack_mode (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW mode request.
 
int newCallBack_reconfigure (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW reconfigure request.
 
int setCropMode (const mx::meta::trueFalseT< true > &t)
 Interface to setCropMode when the derivedT has crop mode.
 
int setCropMode (const mx::meta::trueFalseT< false > &f)
 Interface to setCropMode when the derivedT does not have crop mode.
 
int newCallBack_cropMode (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW cropMode request.
 
int newCallBack_roi_x (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_x request.
 
int newCallBack_roi_y (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_y request.
 
int newCallBack_roi_w (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_w request.
 
int newCallBack_roi_h (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_h request.
 
int newCallBack_roi_bin_x (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW bin_x request.
 
int newCallBack_roi_bin_y (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW bin_y request.
 
int checkNextROI (const mx::meta::trueFalseT< true > &t)
 Interface to checkNextROI when the derivedT uses ROIs.
 
int checkNextROI (const mx::meta::trueFalseT< false > &f)
 Interface to checkNextROI when the derivedT does not use ROIs.
 
int newCallBack_roi_check (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_check request.
 
int setNextROI (const mx::meta::trueFalseT< true > &t)
 Interface to setNextROI when the derivedT uses ROIs.
 
int setNextROI (const mx::meta::trueFalseT< false > &f)
 Interface to setNextROI when the derivedT does not use ROIs.
 
int newCallBack_roi_set (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_set request.
 
int newCallBack_roi_full (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_full request.
 
int newCallBack_roi_fullbin (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_fullbin request.
 
int newCallBack_roi_loadlast (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_loadlast request.
 
int newCallBack_roi_last (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_last request.
 
int newCallBack_roi_default (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW roi_default request.
 
int setShutter (int ss, const mx::meta::trueFalseT< true > &t)
 Interface to setShutter when the derivedT has a shutter.
 
int setShutter (int ss, const mx::meta::trueFalseT< false > &f)
 Interface to setShutter when the derivedT does not have a shutter.
 
int newCallBack_shutter (const pcf::IndiProperty &ipRecv)
 Callback to process a NEW shutter request.
 
std::string stateString (const mx::meta::trueFalseT< true > &t)
 Interface to stateString when the derivedT provides it.
 
std::string stateString (const mx::meta::trueFalseT< false > &f)
 Interface to stateString when the derivedT does not provide it.
 
bool stateStringValid (const mx::meta::trueFalseT< true > &t)
 Interface to stateStringValid when the derivedT provides it.
 
bool stateStringValid (const mx::meta::trueFalseT< false > &f)
 Interface to stateStringValid when the derivedT does not provide it.
 
int updateINDI ()
 Update the INDI properties for this device controller.
 
static int st_newCallBack_stdCamera (void *app, const pcf::IndiProperty &ipRecv)
 The static callback function to be registered for stdCamera properties.
 

Signal Handling

libMagAOX/logger/types/software_log.hpp

static MagAOXAppm_self = nullptr
 
int setSigTermHandler ()
 Sets the handler for SIGTERM, SIGQUIT, and SIGINT.
 
void handlerSigTerm (int signum, siginfo_t *siginf, void *ucont)
 Handles SIGTERM, SIGQUIT, and SIGINT. Sets m_shutdown to 1 and logs the signal.
 
static void _handlerSigTerm (int signum, siginfo_t *siginf, void *ucont)
 The handler called when SIGTERM, SIGQUIT, or SIGINT is received. Just a wrapper for handlerSigTerm.
 

Privilege Management

uid_t m_euidReal
 The real user id of the proces (i.e. the lower privileged id of the user)
 
uid_t m_euidCalled
 
uid_t m_suid
 The save-set user id of the process.
 
int setEuidCalled ()
 Set the effective user ID to the called value, i.e. the highest possible.
 
int setEuidReal ()
 Set the effective user ID to the real value, i.e. the file owner.
 

Detailed Description

MagAO-X application to control the OCAM 2K EMCCD

Definition at line 46 of file ocam2KCtrl.hpp.

Member Typedef Documentation

◆ callBackInsertResult

template<bool _useINDI = true>
typedef std::pair<callBackIterator, bool> MagAOX::app::MagAOXApp< _useINDI >::callBackInsertResult
inherited

Return type of insert on the indiCallBack map.

Definition at line 666 of file MagAOXApp.hpp.

◆ callBackIterator

template<bool _useINDI = true>
typedef std::unordered_map<std::string,indiCallBack>::iterator MagAOX::app::MagAOXApp< _useINDI >::callBackIterator
inherited

Iterator type of the indiCallBack map.

Definition at line 663 of file MagAOXApp.hpp.

◆ callBackValueType

template<bool _useINDI = true>
typedef std::pair<std::string, indiCallBack> MagAOX::app::MagAOXApp< _useINDI >::callBackValueType
inherited

Value type of the indiCallBack map.

Definition at line 660 of file MagAOXApp.hpp.

◆ cbIndexT

Definition at line 108 of file frameGrabber.hpp.

◆ logManagerT [1/2]

The log manager type.

Definition at line 79 of file telemeter.hpp.

◆ logManagerT [2/2]

template<bool _useINDI = true>
typedef logger::logManager<MagAOXApp<_useINDI>, logFileRaw<verboseT> > MagAOX::app::MagAOXApp< _useINDI >::logManagerT
inherited

The log manager type.

Definition at line 167 of file MagAOXApp.hpp.

◆ MagAOXAppT

◆ verboseT [1/2]

Definition at line 76 of file telemeter.hpp.

◆ verboseT [2/2]

template<bool _useINDI = true>
typedef XWC_DEFAULT_VERBOSITY MagAOX::app::MagAOXApp< _useINDI >::verboseT
inherited

Definition at line 164 of file MagAOXApp.hpp.

Member Enumeration Documentation

◆ fgFlip

Definition at line 100 of file frameGrabber.hpp.

Constructor & Destructor Documentation

◆ ocam2KCtrl()

◆ ~ocam2KCtrl()

MagAOX::app::ocam2KCtrl::~ocam2KCtrl ( )
inlinenoexcept

Destructor.

Definition at line 363 of file ocam2KCtrl.hpp.

Member Function Documentation

◆ _handlerSigTerm()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::_handlerSigTerm ( int  signum,
siginfo_t siginf,
void ucont 
)
staticprivateinherited

The handler called when SIGTERM, SIGQUIT, or SIGINT is received. Just a wrapper for handlerSigTerm.

Parameters
[in]signumspecifies the signal.
[in]siginfignored by MagAOXApp
[in]ucontignored by MagAOXApp

Definition at line 2169 of file MagAOXApp.hpp.

References MagAOX::app::MagAOXApp< _useINDI >::handlerSigTerm().

◆ acquireAndCheckValid()

int MagAOX::app::ocam2KCtrl::acquireAndCheckValid ( )
inline

◆ appLogic()

◆ appShutdown()

◆ appStartup()

◆ basePath()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::basePath ( )
inherited

Get the.

Returns
the value of m_ *

Definition at line 3760 of file MagAOXApp.hpp.

Referenced by MagAOX::app::streamWriter::loadConfig().

◆ calibDir()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::calibDir ( )
inherited

Get the calibration directory.

Returns
the value of m_calibDir

Definition at line 3784 of file MagAOXApp.hpp.

◆ checkConfig()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::checkConfig ( )
virtualinherited

Check for unused and unrecognized config options and settings.

Logs the unused targets as warnings. Unrecognized and unused options are logged as critical, and m_shutdown is set. Any command line argument (not an option) will also be critical and cause shutdown.

Definition at line 1602 of file MagAOXApp.hpp.

References MagAOX::app::it, flatlogs::logPrio::LOG_CRITICAL, flatlogs::logPrio::LOG_WARNING, and MagAOX::app::msg.

◆ checkNextROI() [1/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::checkNextROI ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to checkNextROI when the derivedT does not use ROIs.

Tag-dispatch resolution of c_stdCamera_usesROI==false will call this function. This prevents requiring derivedT to have its own checkNextROI().

Definition at line 910 of file stdCamera.hpp.

◆ checkNextROI() [2/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::checkNextROI ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to checkNextROI when the derivedT uses ROIs.

Tag-dispatch resolution of c_stdCamera_usesROI==true will call this function. Calls derivedT::checkNextROI.

Definition at line 904 of file stdCamera.hpp.

◆ checkRecordTimes() [1/4]

int MagAOX::app::ocam2KCtrl::checkRecordTimes ( )
inline

Definition at line 1517 of file ocam2KCtrl.hpp.

References MagAOX::app::MagAOXApp< _useINDI >::log().

◆ checkRecordTimes() [2/4]

int MagAOX::app::dev::telemeter< ocam2KCtrl >::checkRecordTimes ( const telT &  tel,
telTs...  tels 
)
inherited

Check the time of the last record for each telemetry type and make an entry if needed.

This must be called from derivedT::checkRecordTimes(), with one template parameter for ach telemetry log type being recorded.

Returns
0 on succcess
-1 on error
Parameters
[in]tel[unused] object of the telemetry type to record
[in]tels[unused] objects of the additional telemetry types to record

Definition at line 156 of file telemeter.hpp.

◆ checkRecordTimes() [3/4]

int MagAOX::app::dev::telemeter< ocam2KCtrl >::checkRecordTimes ( timespec &  ts)
inherited

Empty function called at the end of the template list.

Returns
0 on succcess
-1 on error
Parameters
[in]ts[unused] the timestamp that records are compared to

Definition at line 177 of file telemeter.hpp.

◆ checkRecordTimes() [4/4]

int MagAOX::app::dev::telemeter< ocam2KCtrl >::checkRecordTimes ( timespec &  ts,
const telT &  tel,
telTs...  tels 
)
inherited

Worker function to actually perform the record time checking logic.

Recursively calls itself until the variadic template list is exhausted.

Returns
0 on succcess
-1 on error
Parameters
[in]ts[unused] the timestamp that records are compared to
[in]tel[unused] objects of the telemetry type to record
[in]tels[unused] objects of the additional telemetry types to record

Definition at line 167 of file telemeter.hpp.

◆ clearFSMAlert()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::clearFSMAlert ( )
privateinherited

Clear the FSM alert state.

This can only be done from within this class, and this should only be possible via user action via INDI.

Definition at line 2630 of file MagAOXApp.hpp.

References INDI_ALERT, INDI_BUSY, INDI_IDLE, INDI_OK, and flatlogs::logPrio::LOG_WARNING.

◆ configBase()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::configBase ( )
inherited

Get the config base file.

Returns
the value of m_confgBase

Definition at line 3778 of file MagAOXApp.hpp.

◆ configCircBuffs()

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::configCircBuffs ( )
inherited

Definition at line 241 of file frameGrabber.hpp.

◆ configDir()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::configDir ( )
inherited

Get the config directory.

Returns
the current value of m_configDir

Definition at line 3772 of file MagAOXApp.hpp.

◆ configLog()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::configLog ( const std::string &  name,
const int code,
const std::string &  value,
const std::string &  source 
)
staticprotectedinherited

Callback for config system logging.

Called by appConfigurator each time a value is set using the config() operator. You never need to call this directly.

Parameters
[in]nameThe name of the config value
[in]codenumeric code specifying the type
[in]valuethe value read by the config system
[in]sourcethe source of the value.

Definition at line 2089 of file MagAOXApp.hpp.

◆ configName()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::configName ( )
inherited

Get the config name.

Returns
the current value of m_configName

Definition at line 3766 of file MagAOXApp.hpp.

Referenced by MagAOX::app::andorCtrl::loadConfig(), libXWCTest::appTest::MagAOXAppTest::SCENARIO(), TEST_CASE(), and MagAOX::app::andorCtrl::writeConfig().

◆ configureAcquisition()

int MagAOX::app::ocam2KCtrl::configureAcquisition ( )
inline

◆ cpusetPath()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::cpusetPath ( )
inherited

Get the cpuset path.

Returns
the value of m_cpusetPath

Definition at line 3802 of file MagAOXApp.hpp.

◆ createINDIFIFOS()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createINDIFIFOS ( )
protectedinherited

Create the INDI FIFOs.

Changes permissions to max available and creates the FIFOs at the configured path.

Todo:
make driver FIFO path full configurable.

Definition at line 3099 of file MagAOXApp.hpp.

References flatlogs::logPrio::LOG_CRITICAL, and MAGAOX_driverFIFORelPath.

◆ createReadoutSpeed() [1/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::createReadoutSpeed ( const mx::meta::trueFalseT< false > &  f)
protectedinherited

◆ createReadoutSpeed() [2/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::createReadoutSpeed ( const mx::meta::trueFalseT< true > &  t)
protectedinherited

Definition at line 549 of file stdCamera.hpp.

◆ createROIndiNumber()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createROIndiNumber ( pcf::IndiProperty &  prop,
const std::string &  propName,
const std::string &  propLabel = "",
const std::string &  propGroup = "" 
)
inherited

Create a ReadOnly INDI Number property.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]propNamethe name of the property
[in]propLabel[optional] the GUI label suggestion for this property
[in]propGroup[optional] the group for this property

Definition at line 2785 of file MagAOXApp.hpp.

Referenced by MagAOX::app::picamCtrl::appStartup(), and MagAOX::app::zaberCtrl::appStartup().

◆ createROIndiText()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createROIndiText ( pcf::IndiProperty &  prop,
const std::string &  propName,
const std::string &  elName,
const std::string &  propLabel = "",
const std::string &  propGroup = "",
const std::string &  elLabel = "" 
)
inherited

Create a standard ReadOnly INDI Text property, with at least one element.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]propNamethe name of the property
[in]elNamethe name of the element
[in]propLabel[optional] the GUI label suggestion for this property
[in]propGroup[optional] the group for this property
[in]elLabel[optional] the GUI label suggestion for the element

Definition at line 2702 of file MagAOXApp.hpp.

◆ createStandardIndiNumber()

template<bool _useINDI>
template<typename T >
int MagAOX::app::MagAOXApp< _useINDI >::createStandardIndiNumber ( pcf::IndiProperty &  prop,
const std::string &  name,
const T &  min,
const T &  max,
const T &  step,
const std::string &  format,
const std::string &  label = "",
const std::string &  group = "" 
)
inherited

Create a standard R/W INDI Number property with target and current elements.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]namethe name of the property
[in]minthe minimum value for the elements, applied to both target and current
[in]maxthe minimum value for the elements, applied to both target and current
[in]stepthe step size for the elements, applied to both target and current
[in]formatthe _ value for the elements, applied to both target and current. Set to "" to use the MagAO-X standard for type.
[in]label[optional] the GUI label suggestion for this property
[in]group[optional] the group for this property

Definition at line 2738 of file MagAOXApp.hpp.

Referenced by MagAOX::app::picoMotorCtrl::appStartup().

◆ createStandardIndiRequestSw()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createStandardIndiRequestSw ( pcf::IndiProperty &  prop,
const std::string &  name,
const std::string &  label = "",
const std::string &  group = "" 
)
inherited

Create a standard R/W INDI switch with a single request element.

This switch is intended to function like a momentary switch.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]namethe name of the property
[in]label[optional] the GUI label suggestion for this property
[in]group[optional] the group for this property

Definition at line 2841 of file MagAOXApp.hpp.

Referenced by appStartup().

◆ createStandardIndiSelectionSw() [1/2]

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createStandardIndiSelectionSw ( pcf::IndiProperty &  prop,
const std::string &  name,
const std::vector< std::string > &  elements,
const std::string &  label = "",
const std::string &  group = "" 
)
inherited

Create a standard R/W INDI selection (one of many) switch with vector of elements using the element strings as their own labels This switch is intended to function like drop down menu.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]namethe name of the property,
[in]elementsthe element names to give to the switches
[in]label[optional] the GUI label suggestion for this property
[in]group[optional] the group for this property

Definition at line 2916 of file MagAOXApp.hpp.

◆ createStandardIndiSelectionSw() [2/2]

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createStandardIndiSelectionSw ( pcf::IndiProperty &  prop,
const std::string &  name,
const std::vector< std::string > &  elements,
const std::vector< std::string > &  elementLabels,
const std::string &  label = "",
const std::string &  group = "" 
)
inherited

Create a standard R/W INDI selection (one of many) switch with vector of elements and element labels.

This switch is intended to function like drop down menu.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]namethe name of the property,
[in]elementsthe element names to give to the switches
[in]elementLabelsthe element labels to give to the switches
[in]label[optional] the GUI label suggestion for this property
[in]group[optional] the group for this property

Definition at line 2871 of file MagAOXApp.hpp.

Referenced by MagAOX::app::picoMotorCtrl::appStartup().

◆ createStandardIndiText()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createStandardIndiText ( pcf::IndiProperty &  prop,
const std::string &  propName,
const std::string &  label = "",
const std::string &  group = "" 
)
inherited

Create a standard R/W INDI Text property with target and current elements.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]propNamethe name of the property
[in]label[optional] the GUI label suggestion for this property
[in]group[optional] the group for this property

Definition at line 2674 of file MagAOXApp.hpp.

◆ createStandardIndiToggleSw()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::createStandardIndiToggleSw ( pcf::IndiProperty &  prop,
const std::string &  name,
const std::string &  label = "",
const std::string &  group = "" 
)
inherited

Create a standard R/W INDI switch with a single toggle element.

This switch is intended to function like an on/off toggle switch.

Returns
0 on success
-1 on error
Parameters
[out]propthe property to create and setup
[in]namethe name of the property
[in]label[optional] the GUI label suggestion for this property
[in]group[optional] the group for this property

Definition at line 2811 of file MagAOXApp.hpp.

Referenced by MagAOX::app::siglentSDG::appStartup(), MagAOX::app::streamWriter::appStartup(), and MagAOX::app::sysMonitor::appStartup().

◆ createVShiftSpeed() [1/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::createVShiftSpeed ( const mx::meta::trueFalseT< false > &  f)
protectedinherited

◆ createVShiftSpeed() [2/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::createVShiftSpeed ( const mx::meta::trueFalseT< true > &  t)
protectedinherited

Definition at line 553 of file stdCamera.hpp.

◆ derived()

ocam2KCtrl & MagAOX::app::dev::stdCamera< ocam2KCtrl >::derived ( )
inlineprivateinherited

Definition at line 1044 of file stdCamera.hpp.

◆ driverCtrlName()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::driverCtrlName ( )
inherited

Get the INDI control FIFO file name.

Returns
the current value of m_driverCtrlName

Definition at line 3832 of file MagAOXApp.hpp.

◆ driverInName()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::driverInName ( )
inherited

Get the INDI input FIFO file name.

Returns
the current value of m_driverInName

Definition at line 3820 of file MagAOXApp.hpp.

◆ driverOutName()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::driverOutName ( )
inherited

Get the INDI output FIFO file name.

Returns
the current value of m_driverOutName

Definition at line 3826 of file MagAOXApp.hpp.

◆ execute()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::execute ( )
virtualinherited

The execute method implementing the standard main loop. Should not normally be overridden.

Performs final startup steps. That is:

  • Verifies correct effective user-id by comparison to logs directory.
  • PID locking lockPID()
  • log thread startup by logThreadStart()
  • signal handling installation by setSigTermHandler()
  • appStartup() is called
  • INDI communications started by startINDI()
  • power state is checked, pausing if unknown (if being managed)

Errors in the above steps will cause a process exit.

Then commences the main event loop. Conditions on entry to the main loop:

  • PID locked
  • Log thread running
  • Signal handling installed
  • appStartup successful
  • INDI communications started successfully (if being used)
  • power state known (if being managed)

In the event loop, the power state is checked (if being managed). If power is off, then onPowerOff is called. If power is on, or power is not managed, appLogic is called. These methods are implemented in derived classes, and are called every m_loopPause interval.

If an error is returned by either onPowerOff or appLogic, or a signal is handled, then the shutdown is managed. This includes shutting down INDI, calling appShutdown, and unlocking the PID. The log thread will shutdown.

Todo:
Need a heartbeat update here.

Definition at line 1669 of file MagAOXApp.hpp.

References flatlogs::logPrio::LOG_CRITICAL.

◆ fgThreadExec()

void MagAOX::app::dev::frameGrabber< ocam2KCtrl >::fgThreadExec ( )
protectedinherited

Execute framegrabbing.

Todo:
this ought to wait until OPERATING, using READY as a sign of "not integrating"

Definition at line 261 of file frameGrabber.hpp.

◆ fgThreadStart()

void MagAOX::app::dev::frameGrabber< ocam2KCtrl >::fgThreadStart ( frameGrabber< ocam2KCtrl > *  o)
staticprotectedinherited

Thread starter, called by MagAOXApp::threadStart on thread construction. Calls fgThreadExec.

Parameters
[in]oa pointer to a frameGrabber instance (normally this)

Definition at line 258 of file frameGrabber.hpp.

◆ fps()

float MagAOX::app::ocam2KCtrl::fps ( )
inline

Implementation of the frameGrabber fps interface.

Just returns the value of m_fps

Definition at line 1324 of file ocam2KCtrl.hpp.

References MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_fps.

Referenced by getFPS().

◆ getEMGain()

◆ getFPS()

◆ getTemps()

◆ gitAlert()

template<bool _useINDI>
bool MagAOX::app::MagAOXApp< _useINDI >::gitAlert ( )
inherited

Get the value of the git alert flag.

Returns
the current value of m_gitAlert

Definition at line 2609 of file MagAOXApp.hpp.

◆ handleDefProperty()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::handleDefProperty ( const pcf::IndiProperty &  ipRecv)
inherited

Handler for the DEF INDI properties notification.

Uses the properties registered in m_indiSetCallBacks to process the notification. This is called by m_indiDriver's indiDriver::handleDefProperties.

Parameters
[in]ipRecvThe property being sent.

Definition at line 3262 of file MagAOXApp.hpp.

References MagAOX::app::ipRecv.

◆ handleGetProperties()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::handleGetProperties ( const pcf::IndiProperty &  ipRecv)
inherited

Handler for the get INDI properties request.

Uses the properties registered in m_indiCallBacks to respond to the request. This is called by m_indiDriver's indiDriver::handleGetProperties.

Parameters
[in]ipRecvThe property being requested.

Definition at line 3268 of file MagAOXApp.hpp.

References MagAOX::app::ipRecv, and MagAOX::app::it.

◆ handleNewProperty()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::handleNewProperty ( const pcf::IndiProperty &  ipRecv)
inherited

Handler for the new INDI property request.

Uses the properties registered in m_indiCallBacks to respond to the request, looking up the callback for this property and calling it.

This is called by m_indiDriver's indiDriver::handleGetProperties.

Todo:
handle errors, are they FATAL?
Parameters
[in]ipRecvThe property being changed.

Definition at line 3337 of file MagAOXApp.hpp.

References MagAOX::app::ipRecv.

Referenced by libXWCTest::appTest::MagAOXAppTest::SCENARIO().

◆ handlerSigTerm()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::handlerSigTerm ( int  signum,
siginfo_t siginf,
void ucont 
)
privateinherited

Handles SIGTERM, SIGQUIT, and SIGINT. Sets m_shutdown to 1 and logs the signal.

Parameters
[in]signumspecifies the signal.
[in]siginfignored by MagAOXApp
[in]ucontignored by MagAOXApp

Definition at line 2175 of file MagAOXApp.hpp.

Referenced by MagAOX::app::MagAOXApp< _useINDI >::_handlerSigTerm().

◆ handleSetProperty()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::handleSetProperty ( const pcf::IndiProperty &  ipRecv)
inherited

Handler for the set INDI property request.

This is called by m_indiDriver's indiDriver::handleSetProperties.

Todo:
handle errors, are they FATAL?
Todo:
log an error here because callBack should not be null
Todo:
log invalid SetProperty request.
Parameters
[in]ipRecvThe property being changed.

Definition at line 3362 of file MagAOXApp.hpp.

References MagAOX::app::ipRecv.

◆ INDI_NEWCALLBACK_DECL()

MagAOX::app::ocam2KCtrl::INDI_NEWCALLBACK_DECL ( ocam2KCtrl  ,
m_indiP_emProtReset   
)

◆ INDI_SETCALLBACK_DECL() [1/2]

template<bool _useINDI = true>
MagAOX::app::MagAOXApp< _useINDI >::INDI_SETCALLBACK_DECL ( MagAOXApp< _useINDI ,
m_indiP_powerChannel   
)
inherited

◆ INDI_SETCALLBACK_DECL() [2/2]

MagAOX::app::ocam2KCtrl::INDI_SETCALLBACK_DECL ( ocam2KCtrl  ,
m_indiP_syncFreq   
)

◆ indiTargetUpdate()

template<bool _useINDI>
template<typename T >
int MagAOX::app::MagAOXApp< _useINDI >::indiTargetUpdate ( pcf::IndiProperty &  localProperty,
T &  localTarget,
const pcf::IndiProperty &  remoteProperty,
bool  setBusy = true 
)
protectedinherited

Get the target element value from an new property.

Returns
0 on success
-1 on error
Parameters
[out]localPropertyThe local property to update
[out]localTargetThe local value to update
[in]remotePropertythe new property received
[in]setBusy[optional] set property to busy if true

Definition at line 3490 of file MagAOXApp.hpp.

References INDI_BUSY, and flatlogs::logPrio::LOG_ERROR.

Referenced by MagAOX::app::picoMotorCtrl::newCallBack_picopos().

◆ loadBasicConfig()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::loadBasicConfig ( )
virtualinherited

The basic MagAO-X configuration processing method. Should not normally be overridden.

This method processes the standard MagAO-X key=value pairs.

Though it is virtual, it should not normally be overridden unless you need to depart from the MagAO-X standard.

Processing of app specific config goes in loadConfig() implemented by the derived class.

Definition at line 1543 of file MagAOXApp.hpp.

References INDI_SETCALLBACK, flatlogs::logPrio::LOG_CRITICAL, and flatlogs::logPrio::LOG_ERROR.

◆ loadConfig() [1/6]

◆ loadConfig() [2/6]

int MagAOX::app::dev::telemeter< ocam2KCtrl >::loadConfig ( appConfigurator &  config)
inherited

Load the device section from an application configurator.

Returns
0 on success
-1 on error (nothing implemented yet)
Parameters
[in]configan application configuration from which to load values

Definition at line 120 of file telemeter.hpp.

◆ loadConfig() [3/6]

void MagAOX::app::dev::dssShutter< ocam2KCtrl >::loadConfig ( mx::app::appConfigurator &  config)
inherited

load the configuration system results

This should be called in derivedT::loadConfig as

dssShutter<derivedT>::loadConfig(config);

with appropriate error checking.

Parameters
[in]configthe derived classes configurator

Definition at line 88 of file dssShutter.hpp.

◆ loadConfig() [4/6]

void MagAOX::app::dev::edtCamera< ocam2KCtrl >::loadConfig ( mx::app::appConfigurator &  config)
inherited

load the configuration system results

This should be called in derivedT::loadConfig as

edtCamera<derivedT>::loadConfig(config);

with appropriate error checking.

Parameters
[in]configthe derived classes configurator

Definition at line 125 of file edtCamera.hpp.

◆ loadConfig() [5/6]

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::loadConfig ( mx::app::appConfigurator &  config)
inherited

load the configuration system results

This should be called in derivedT::loadConfig as

framegrabber<derivedT>::loadConfig(config);

with appropriate error checking.

Parameters
[in]configthe derived classes configurator

Definition at line 190 of file frameGrabber.hpp.

◆ loadConfig() [6/6]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::loadConfig ( mx::app::appConfigurator &  config)
inherited

load the configuration system results

This should be called in derivedT::loadConfig as

stdCamera<derivedT>::loadConfig(config);

with appropriate error checking.

Parameters
[in]configthe derived classes configurator

Definition at line 545 of file stdCamera.hpp.

◆ loadImageIntoStream()

int MagAOX::app::ocam2KCtrl::loadImageIntoStream ( void dest)
inline

Implementation of the framegrabber loadImageIntoStream interface.

Conducts the OCAM descramble.

Returns
0 on success
-1 on error
Parameters
[in]dest

Definition at line 1404 of file ocam2KCtrl.hpp.

References b(), MagAOX::app::MagAOXApp< _useINDI >::log(), m_digitalBin, m_digitalBinWork, m_digitalBinX, MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_height, MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_image_p, m_ocam2_id, MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_width, and ocam2_descramble().

◆ loadImageIntoStreamCopy()

void * MagAOX::app::dev::frameGrabber< ocam2KCtrl >::loadImageIntoStreamCopy ( void *  dest,
void *  src,
size_t  width,
size_t  height,
size_t  szof 
)
protectedinherited

Definition at line 265 of file frameGrabber.hpp.

◆ lockPID()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::lockPID ( )
protectedinherited

Attempt to lock the PID by writing it to a file. Fails if a process is already running with the same config name. First checks the PID file for an existing PID. If found, interrogates /proc to determine if that process is running and if so if the command line matches. If a matching process is currently running, then this returns an error.

Will not fail if a PID file exists but the stored PID does not correspond to a running process with the same command line name.

Reference: https://linux.die.net/man/3/getpid

Returns
0 on success.
-1 on any error, including creating the PID file or if this app is already running.

Definition at line 2245 of file MagAOXApp.hpp.

◆ log() [1/2]

template<bool _useINDI>
template<typename logT , int retval>
int MagAOX::app::MagAOXApp< _useINDI >::log ( const typename logT::messageT &  msg,
logPrioT  level = logPrio::LOG_DEFAULT 
)
staticinherited

Make a log entry.

Wrapper for logManager::log

Template Parameters
logTthe log entry type
retvalthe value returned by this method.
Parameters
[in]msgthe message to log
[in]level[optional] the log level. The default is used if not specified.

Definition at line 2030 of file MagAOXApp.hpp.

References MagAOX::app::msg.

Referenced by SMCTEST::cameraSim_test::cameraSim_test(), MagAOX::app::picoMotorCtrl::motorChannel::motorChannel(), SDGTEST::siglentSDG_test::siglentSDG_test(), SMCTEST::smc100ccCtrl_test::smc100ccCtrl_test(), MagAOX::app::streamWriter_test::streamWriter_test(), SYSMONTEST::sysMonitor_test::sysMonitor_test(), ZCTRLTEST::zaberCtrl_test::zaberCtrl_test(), MagAOX::app::zylaCtrl::zylaCtrl(), MagAOX::app::picamCtrl::~picamCtrl(), MagAOX::app::streamWriter::~streamWriter(), MagAOX::app::zylaCtrl::~zylaCtrl(), visxCtrl.xapp.VisX::_gather_metadata(), MagAOX::app::mzmqClient::_handlerSigSegv(), MagAOX::app::mzmqServer::_handlerSigSegv(), MagAOX::app::streamWriter::_handlerSigSegv(), visxCtrl.xapp.VisX::_init_properties(), MagAOX::app::qhyCtrl::AbortAcquisition(), MagAOX::app::andorCtrl::acquireAndCheckValid(), MagAOX::app::baslerCtrl::acquireAndCheckValid(), MagAOX::app::cameraSim::acquireAndCheckValid(), acquireAndCheckValid(), MagAOX::app::picamCtrl::acquireAndCheckValid(), MagAOX::app::zylaCtrl::acquireAndCheckValid(), MagAOX::app::streamWriter::allocate_circbufs(), MagAOX::app::streamWriter::allocate_xrif(), MagAOX::app::acronameUsbHub::appLogic(), MagAOX::app::andorCtrl::appLogic(), MagAOX::app::baslerCtrl::appLogic(), MagAOX::app::cameraSim::appLogic(), MagAOX::app::filterWheelCtrl::appLogic(), MagAOX::app::hsfwCtrl::appLogic(), MagAOX::app::mzmqClient::appLogic(), MagAOX::app::mzmqServer::appLogic(), appLogic(), MagAOX::app::picamCtrl::appLogic(), MagAOX::app::picoMotorCtrl::appLogic(), MagAOX::app::qhyCtrl::appLogic(), MagAOX::app::siglentSDG::appLogic(), MagAOX::app::smc100ccCtrl::appLogic(), MagAOX::app::streamWriter::appLogic(), MagAOX::app::sysMonitor::appLogic(), MagAOX::app::trippLitePDU::appLogic(), MagAOX::app::ttmModulator::appLogic(), MagAOX::app::xt1121Ctrl::appLogic(), MagAOX::app::xt1121DCDU::appLogic(), MagAOX::app::zaberCtrl::appLogic(), MagAOX::app::zylaCtrl::appLogic(), MagAOX::app::andorCtrl::appShutdown(), MagAOX::app::baslerCtrl::appShutdown(), MagAOX::app::hsfwCtrl::appShutdown(), MagAOX::app::mzmqClient::appShutdown(), MagAOX::app::mzmqServer::appShutdown(), MagAOX::app::picamCtrl::appShutdown(), MagAOX::app::picoMotorCtrl::appShutdown(), MagAOX::app::qhyCtrl::appShutdown(), MagAOX::app::streamWriter::appShutdown(), MagAOX::app::zylaCtrl::appShutdown(), MagAOX::app::acronameUsbHub::appStartup(), MagAOX::app::andorCtrl::appStartup(), MagAOX::app::baslerCtrl::appStartup(), MagAOX::app::cameraSim::appStartup(), MagAOX::app::filterWheelCtrl::appStartup(), MagAOX::app::hsfwCtrl::appStartup(), MagAOX::app::magAOXMaths::appStartup(), MagAOX::app::mzmqClient::appStartup(), MagAOX::app::mzmqServer::appStartup(), appStartup(), MagAOX::app::picamCtrl::appStartup(), MagAOX::app::picoMotorCtrl::appStartup(), MagAOX::app::qhyCtrl::appStartup(), MagAOX::app::siglentSDG::appStartup(), MagAOX::app::smc100ccCtrl::appStartup(), MagAOX::app::streamWriter::appStartup(), MagAOX::app::sysMonitor::appStartup(), MagAOX::app::trippLitePDU::appStartup(), MagAOX::app::xt1121DCDU::appStartup(), MagAOX::app::zaberCtrl::appStartup(), MagAOX::app::zylaCtrl::appStartup(), MagAOX::app::ttmModulator::calcState(), MagAOX::app::andorCtrl::cameraSelect(), MagAOX::app::zylaCtrl::cameraSelect(), visxCtrl.xapp.VisX::cancel_exposure(), MagAOX::app::picamCtrl::capExpTime(), MagAOX::app::siglentSDG::changeAmp(), MagAOX::app::siglentSDG::changeAmp(), MagAOX::app::siglentSDG::changeFreq(), MagAOX::app::siglentSDG::changeFreq(), MagAOX::app::siglentSDG::changeOfst(), MagAOX::app::siglentSDG::changeOfst(), MagAOX::app::siglentSDG::changeOutp(), MagAOX::app::siglentSDG::changeOutp(), MagAOX::app::siglentSDG::changePhse(), MagAOX::app::siglentSDG::changePhse(), MagAOX::app::siglentSDG::changeSync(), MagAOX::app::siglentSDG::changeSync(), MagAOX::app::siglentSDG::changeWdth(), MagAOX::app::siglentSDG::changeWdth(), MagAOX::app::siglentSDG::changeWvtp(), MagAOX::app::siglentSDG::changeWvtp(), MagAOX::app::xt1121Ctrl::channelSetCallback(), MagAOX::app::picoMotorCtrl::channelThreadExec(), MagAOX::app::picoMotorCtrl::channelThreadStart(), MagAOX::app::baslerCtrl::checkNextROI(), MagAOX::app::andorCtrl::checkRecordTimes(), MagAOX::app::baslerCtrl::checkRecordTimes(), MagAOX::app::cameraSim::checkRecordTimes(), checkRecordTimes(), MagAOX::app::picamCtrl::checkRecordTimes(), MagAOX::app::qhyCtrl::checkRecordTimes(), MagAOX::app::siglentSDG::checkRecordTimes(), MagAOX::app::smc100ccCtrl::checkRecordTimes(), MagAOX::app::sysMonitor::checkRecordTimes(), MagAOX::app::zaberCtrl::checkRecordTimes(), MagAOX::app::zylaCtrl::checkRecordTimes(), MagAOX::app::siglentSDG::checkSetup(), MagAOX::app::andorCtrl::configureAcquisition(), MagAOX::app::baslerCtrl::configureAcquisition(), MagAOX::app::cameraSim::configureAcquisition(), configureAcquisition(), MagAOX::app::picamCtrl::configureAcquisition(), MagAOX::app::qhyCtrl::configureAcquisition(), MagAOX::app::zylaCtrl::configureAcquisition(), MagAOX::app::baslerCtrl::connect(), MagAOX::app::picamCtrl::connect(), MagAOX::app::qhyCtrl::connect(), MagAOX::app::sysMonitor::criticalCoreTemperature(), MagAOX::app::sysMonitor::criticalDiskTemperature(), MagAOX::app::trippLitePDU::devConnect(), MagAOX::app::trippLitePDU::devLogin(), MagAOX::app::trippLitePDU::devPostLogin(), MagAOX::app::trippLitePDU::devStatus(), MagAOX::app::streamWriter::doEncode(), MagAOX::app::streamWriter::fgThreadExec(), MagAOX::app::streamWriter::fgThreadStart(), visxCtrl.xapp.VisX::finalize_exposure(), MagAOX::app::sysMonitor::findChronyStatus(), MagAOX::app::sysMonitor::findCPULoads(), MagAOX::app::sysMonitor::findCPUTemperatures(), MagAOX::app::sysMonitor::findDiskTemperature(), MagAOX::app::sysMonitor::findDiskUsage(), MagAOX::app::sysMonitor::findRamUsage(), camtipSR.core.camtipSR::fit_SR_EE(), camtipSR.core.camtipSR::fit_SR_gauss(), MagAOX::app::picamCtrl::getAcquisitionState(), MagAOX::app::streamWriter::getCircBuffLengths(), MagAOX::app::smc100ccCtrl::getCtrlState(), MagAOX::app::andorCtrl::getEMGain(), getEMGain(), MagAOX::app::baslerCtrl::getExpTime(), MagAOX::app::qhyCtrl::getExpTime(), MagAOX::app::andorCtrl::getFPS(), getFPS(), MagAOX::app::smc100ccCtrl::getLastError(), MagAOX::app::filterWheelCtrl::getMoving(), MagAOX::app::picamCtrl::getPicamParameter(), MagAOX::app::picamCtrl::getPicamParameter(), MagAOX::app::filterWheelCtrl::getPos(), MagAOX::app::smc100ccCtrl::getPosition(), MagAOX::app::xt1121Ctrl::getState(), MagAOX::app::filterWheelCtrl::getSwitch(), MagAOX::app::andorCtrl::getTemp(), MagAOX::app::baslerCtrl::getTemp(), MagAOX::app::qhyCtrl::getTemp(), MagAOX::app::zylaCtrl::getTemp(), getTemps(), MagAOX::app::picamCtrl::getTemps(), camtipSR.core.camtipSR::grab_img(), camtipSR.core.camtipSR::grab_stack(), corAlign.corAlign::handle_closed_loop(), adcCtrl.adcCtrl::handle_ctrl_mtx(), visxCtrl.xapp.VisX::handle_expose(), visxCtrl.xapp.VisX::handle_exptime(), adcCtrl.adcCtrl::handle_gain(), visxCtrl.xapp.VisX::handle_gain(), adcCtrl.adcCtrl::handle_knife_edge(), adcCtrl.adcCtrl::handle_knife_edge_findzero(), adcCtrl.adcCtrl::handle_labmode(), adcCtrl.adcCtrl::handle_n_avg(), camtipSR.core.camtipSR::handle_n_avg(), corAlign.corAlign::handle_n_avg(), camtipSR.core.camtipSR::handle_n_jitter(), adcCtrl.adcCtrl::handle_no_measurements(), adcCtrl.adcCtrl::handle_offset(), audibleAlerts.core.AudibleAlerts::handle_personality_switch(), corAlign.corAlign::handle_ref_x(), corAlign.corAlign::handle_ref_y(), adcCtrl.adcCtrl::handle_reset(), audibleAlerts.core.AudibleAlerts::handle_soundboard_switch(), audibleAlerts.core.AudibleAlerts::handle_speech_request(), audibleAlerts.core.AudibleAlerts::handle_speech_text(), adcCtrl.adcCtrl::handle_state(), corAlign.corAlign::handle_state(), visxCtrl.xapp.VisX::handle_temp_ccd(), MagAOX::app::mzmqClient::handlerSigSegv(), MagAOX::app::mzmqServer::handlerSigSegv(), MagAOX::app::streamWriter::handlerSigSegv(), MagAOX::app::filterWheelCtrl::home(), MagAOX::app::INDI_NEWCALLBACK_DEFN(), dbIngest.dbIngest::ingest_line(), MagAOX::app::streamWriter::initialize_xrif(), dbIngest.dbIngest::launch_followers(), audibleAlerts.core.AudibleAlerts::load_personality(), MagAOX::app::andorCtrl::loadConfig(), MagAOX::app::baslerCtrl::loadConfig(), MagAOX::app::filterWheelCtrl::loadConfig(), MagAOX::app::hsfwCtrl::loadConfig(), MagAOX::app::mzmqClient::loadConfig(), MagAOX::app::mzmqServer::loadConfig(), loadConfig(), MagAOX::app::picoMotorCtrl::loadConfig(), MagAOX::app::qhyCtrl::loadConfig(), MagAOX::app::smc100ccCtrl::loadConfig(), MagAOX::app::streamWriter::loadConfig(), MagAOX::app::sysMonitor::loadConfig(), MagAOX::app::xt1121Ctrl::loadConfig(), MagAOX::app::baslerCtrl::loadConfigImpl(), MagAOX::app::picoMotorCtrl::loadConfigImpl(), MagAOX::app::zaberCtrl::loadConfigImpl(), MagAOX::app::cameraSim::loadConfigImpl(), MagAOX::app::andorCtrl::loadImageIntoStream(), MagAOX::app::baslerCtrl::loadImageIntoStream(), MagAOX::app::cameraSim::loadImageIntoStream(), loadImageIntoStream(), MagAOX::app::picamCtrl::loadImageIntoStream(), MagAOX::app::qhyCtrl::loadImageIntoStream(), MagAOX::app::zylaCtrl::loadImageIntoStream(), adcCtrl.adcCtrl::loop(), audibleAlerts.core.AudibleAlerts::loop(), corAlign.corAlign::loop(), dbIngest.dbIngest::loop(), visxCtrl.xapp.VisX::loop(), MagAOX::app::smc100ccCtrl::makeCom(), corAlign.corAlign::measure_fpm_mask_shift(), MagAOX::app::ttmModulator::modTTM(), MagAOX::app::filterWheelCtrl::moveTo(), MagAOX::app::hsfwCtrl::moveTo(), MagAOX::app::zaberCtrl::moveTo(), MagAOX::app::smc100ccCtrl::moveTo(), MagAOX::app::filterWheelCtrl::moveToRaw(), MagAOX::app::filterWheelCtrl::moveToRawRelative(), MagAOX::app::picoMotorCtrl::newCallBack_picopos(), MagAOX::app::picoMotorCtrl::newCallBack_presetName(), MagAOX::app::siglentSDG::normalizeSetup(), MagAOX::app::ttmModulator::offset12(), MagAOX::app::ttmModulator::offsetXY(), MagAOX::app::acronameUsbHub::onPowerOff(), MagAOX::app::andorCtrl::onPowerOff(), MagAOX::app::filterWheelCtrl::onPowerOff(), MagAOX::app::hsfwCtrl::onPowerOff(), onPowerOff(), MagAOX::app::picamCtrl::onPowerOff(), MagAOX::app::zylaCtrl::onPowerOff(), MagAOX::app::filterWheelCtrl::onPowerOnConnect(), MagAOX::app::sysMonitor::parseCPULoads(), MagAOX::app::sysMonitor::parseCPUTemperatures(), MagAOX::app::sysMonitor::parseCPUTemperaturesAMD(), MagAOX::app::sysMonitor::parseCPUTemperaturesIntel(), MagAOX::app::sysMonitor::parseDiskTemperature(), MagAOX::app::sysMonitor::parseDiskUsage(), MagAOX::app::trippLitePDU::parsePDUStatus(), MagAOX::app::sysMonitor::parseRamUsage(), MagAOX::app::zylaCtrl::powerOnDefaults(), audibleAlerts.core.AudibleAlerts::preprocess(), MagAOX::app::filterWheelCtrl::presetNumber(), MagAOX::app::smc100ccCtrl::presetNumber(), MagAOX::app::zaberCtrl::presetNumber(), MagAOX::app::siglentSDG::queryARWV(), MagAOX::app::siglentSDG::queryBSWV(), MagAOX::app::siglentSDG::queryBTWV(), MagAOX::app::siglentSDG::queryMDWV(), MagAOX::app::siglentSDG::queryOUTP(), MagAOX::app::siglentSDG::querySWWV(), MagAOX::app::siglentSDG::querySYNC(), audibleAlerts.core.AudibleAlerts::reaction_handler(), MagAOX::app::picoMotorCtrl::readChannelCounts(), MagAOX::app::andorCtrl::reconfig(), reconfig(), MagAOX::app::picamCtrl::reconfig(), MagAOX::app::zylaCtrl::reconfig(), MagAOX::app::sysMonitor::recordChronyStatus(), MagAOX::app::sysMonitor::recordCoreLoads(), MagAOX::app::sysMonitor::recordCoreTemps(), MagAOX::app::sysMonitor::recordDriveTemps(), MagAOX::app::siglentSDG::recordParams(), MagAOX::app::streamWriter::recordSavingState(), MagAOX::app::streamWriter::recordSavingStats(), MagAOX::app::filterWheelCtrl::recordStage(), MagAOX::app::smc100ccCtrl::recordStage(), MagAOX::app::zaberCtrl::recordTelem(), MagAOX::app::sysMonitor::recordUsage(), MagAOX::app::zaberCtrl::recordZaber(), dbIngest.dbIngest::refresh_properties(), visxCtrl.xapp.VisX::refresh_properties(), MagAOX::app::mzmqClient::reportError(), MagAOX::app::mzmqServer::reportError(), MagAOX::app::mzmqClient::reportInfo(), MagAOX::app::mzmqServer::reportInfo(), MagAOX::app::mzmqClient::reportNotice(), MagAOX::app::mzmqServer::reportNotice(), MagAOX::app::mzmqClient::reportWarning(), MagAOX::app::mzmqServer::reportWarning(), dbIngest.dbIngest::rescan_files(), resetEMProtection(), MagAOX::app::ttmModulator::restTTM(), adcCtrl.adcCtrl::send_command(), MagAOX::app::andorCtrl::setCropMode(), MagAOX::app::andorCtrl::setEMGain(), setEMGain(), MagAOX::app::picamCtrl::setEMGain(), MagAOX::app::andorCtrl::setExpTime(), MagAOX::app::baslerCtrl::setExpTime(), MagAOX::app::cameraSim::setExpTime(), MagAOX::app::picamCtrl::setExpTime(), MagAOX::app::qhyCtrl::setExpTime(), MagAOX::app::baslerCtrl::setFPS(), MagAOX::app::cameraSim::setFPS(), setFPS(), MagAOX::app::sysMonitor::setlatThreadExec(), MagAOX::app::sysMonitor::setlatThreadStart(), MagAOX::app::picamCtrl::setPicamParameter(), MagAOX::app::picamCtrl::setPicamParameter(), MagAOX::app::picamCtrl::setPicamParameter(), MagAOX::app::picamCtrl::setPicamParameter(), MagAOX::app::picamCtrl::setPicamParameter(), MagAOX::app::picamCtrl::setPicamParameterOnline(), MagAOX::app::picamCtrl::setPicamParameterOnline(), MagAOX::app::picamCtrl::setPicamParameterOnline(), MagAOX::app::picamCtrl::setPicamParameterOnline(), MagAOX::app::andorCtrl::setReadoutSpeed(), setShutter(), MagAOX::app::picamCtrl::setShutter(), MagAOX::app::zylaCtrl::setShutter(), MagAOX::app::cameraSim::setShutter(), MagAOX::app::andorCtrl::setShutter(), MagAOX::app::mzmqClient::setSigSegvHandler(), MagAOX::app::mzmqServer::setSigSegvHandler(), MagAOX::app::streamWriter::setSigSegvHandler(), setSynchro(), MagAOX::app::andorCtrl::setTempControl(), setTempControl(), MagAOX::app::zylaCtrl::setTempControl(), MagAOX::app::andorCtrl::setTempSetPt(), setTempSetPt(), MagAOX::app::ttmModulator::setTTM(), adcCtrl.adcCtrl::setup(), camtipSR.core.camtipSR::setup(), corAlign.corAlign::setup(), efcControl.efcControl::setup(), MagAOX::app::andorCtrl::setVShiftSpeed(), MagAOX::app::smc100ccCtrl::splitResponse(), MagAOX::app::andorCtrl::startAcquisition(), MagAOX::app::baslerCtrl::startAcquisition(), startAcquisition(), MagAOX::app::zylaCtrl::startAcquisition(), MagAOX::app::hsfwCtrl::startHoming(), MagAOX::app::smc100ccCtrl::startHoming(), MagAOX::app::zaberCtrl::startHoming(), MagAOX::app::baslerCtrl::stateString(), stateString(), MagAOX::app::filterWheelCtrl::stop(), MagAOX::app::smc100ccCtrl::stop(), MagAOX::app::zaberCtrl::stop(), visxCtrl.xapp.VisX::subscribe_to_other_devices(), MagAOX::app::streamWriter::swThreadExec(), MagAOX::app::streamWriter::swThreadStart(), MagAOX::app::smc100ccCtrl::testConnection(), adcCtrl.adcCtrl::transition_to_idle(), camtipSR.core.camtipSR::transition_to_idle(), corAlign.corAlign::transition_to_idle(), MagAOX::app::acronameUsbHub::turnOutletOff(), MagAOX::app::trippLitePDU::turnOutletOff(), MagAOX::app::xt1121DCDU::turnOutletOff(), MagAOX::app::acronameUsbHub::turnOutletOn(), MagAOX::app::trippLitePDU::turnOutletOn(), MagAOX::app::xt1121DCDU::turnOutletOn(), adcCtrl.adcCtrl::update_wavelength(), MagAOX::app::trippLitePDU::updateAlarmsAndWarnings(), MagAOX::app::acronameUsbHub::updateOutletState(), MagAOX::app::trippLitePDU::updateOutletState(), MagAOX::app::xt1121DCDU::updateOutletState(), MagAOX::app::trippLitePDU::updateOutletStates(), MagAOX::app::magAOXMaths::updateVals(), MagAOX::app::sysMonitor::updateVals(), audibleAlerts.core.AudibleAlerts::walkup_handler(), MagAOX::app::andorCtrl::whilePowerOff(), MagAOX::app::filterWheelCtrl::whilePowerOff(), MagAOX::app::hsfwCtrl::whilePowerOff(), whilePowerOff(), MagAOX::app::picamCtrl::whilePowerOff(), MagAOX::app::zylaCtrl::whilePowerOff(), MagAOX::app::picoMotorCtrl::writeChannelCounts(), MagAOX::app::siglentSDG::writeCommand(), MagAOX::app::andorCtrl::writeConfig(), MagAOX::app::siglentSDG::writeRead(), MagAOX::app::xt1121DCDU::xtChannelName(), and MagAOX::app::xt1121DCDU::xtChannelProperty().

◆ log() [2/2]

template<bool _useINDI>
template<typename logT , int retval>
int MagAOX::app::MagAOXApp< _useINDI >::log ( logPrioT  level = logPrio::LOG_DEFAULT)
staticinherited

Make a log entry.

Wrapper for logManager::log

Template Parameters
logTthe log entry type
retvalthe value returned by this method.
Parameters
[in]level[optional] the log level. The default is used if not specified.

Definition at line 2038 of file MagAOXApp.hpp.

Referenced by visxCtrl.xapp.VisX::_gather_metadata(), visxCtrl.xapp.VisX::_init_properties(), visxCtrl.xapp.VisX::cancel_exposure(), visxCtrl.xapp.VisX::finalize_exposure(), camtipSR.core.camtipSR::fit_SR_EE(), camtipSR.core.camtipSR::fit_SR_gauss(), camtipSR.core.camtipSR::grab_img(), camtipSR.core.camtipSR::grab_stack(), corAlign.corAlign::handle_closed_loop(), adcCtrl.adcCtrl::handle_ctrl_mtx(), visxCtrl.xapp.VisX::handle_expose(), visxCtrl.xapp.VisX::handle_exptime(), adcCtrl.adcCtrl::handle_gain(), visxCtrl.xapp.VisX::handle_gain(), adcCtrl.adcCtrl::handle_knife_edge(), adcCtrl.adcCtrl::handle_knife_edge_findzero(), adcCtrl.adcCtrl::handle_labmode(), adcCtrl.adcCtrl::handle_n_avg(), camtipSR.core.camtipSR::handle_n_avg(), corAlign.corAlign::handle_n_avg(), camtipSR.core.camtipSR::handle_n_jitter(), adcCtrl.adcCtrl::handle_no_measurements(), adcCtrl.adcCtrl::handle_offset(), audibleAlerts.core.AudibleAlerts::handle_personality_switch(), corAlign.corAlign::handle_ref_x(), corAlign.corAlign::handle_ref_y(), adcCtrl.adcCtrl::handle_reset(), audibleAlerts.core.AudibleAlerts::handle_soundboard_switch(), audibleAlerts.core.AudibleAlerts::handle_speech_request(), audibleAlerts.core.AudibleAlerts::handle_speech_text(), adcCtrl.adcCtrl::handle_state(), corAlign.corAlign::handle_state(), visxCtrl.xapp.VisX::handle_temp_ccd(), dbIngest.dbIngest::ingest_line(), dbIngest.dbIngest::launch_followers(), audibleAlerts.core.AudibleAlerts::load_personality(), adcCtrl.adcCtrl::loop(), audibleAlerts.core.AudibleAlerts::loop(), corAlign.corAlign::loop(), dbIngest.dbIngest::loop(), visxCtrl.xapp.VisX::loop(), corAlign.corAlign::measure_fpm_mask_shift(), audibleAlerts.core.AudibleAlerts::preprocess(), audibleAlerts.core.AudibleAlerts::reaction_handler(), dbIngest.dbIngest::refresh_properties(), visxCtrl.xapp.VisX::refresh_properties(), dbIngest.dbIngest::rescan_files(), adcCtrl.adcCtrl::send_command(), adcCtrl.adcCtrl::setup(), camtipSR.core.camtipSR::setup(), corAlign.corAlign::setup(), efcControl.efcControl::setup(), visxCtrl.xapp.VisX::subscribe_to_other_devices(), adcCtrl.adcCtrl::transition_to_idle(), camtipSR.core.camtipSR::transition_to_idle(), corAlign.corAlign::transition_to_idle(), adcCtrl.adcCtrl::update_wavelength(), and audibleAlerts.core.AudibleAlerts::walkup_handler().

◆ logMessage()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::logMessage ( bufferPtrT b)
inherited

Handle a log message from the logging system.

This is a callback from the logManager, and is called when the log thread is processing log entries.

Decides whether to display to stderr and whether to send via INDI.

Definition at line 2045 of file MagAOXApp.hpp.

References b(), flatlogs::logPrio::LOG_ERROR, flatlogs::logPrio::LOG_NOTICE, flatlogs::logHeader::logLevel(), MagAOX::logger::logMinStdFormat(), MagAOX::logger::logStdFormat(), MagAOX::app::msg, flatlogs::timespecX::time_ns, flatlogs::timespecX::time_s, and flatlogs::logHeader::timespec().

◆ loopPause()

template<bool _useINDI>
unsigned long MagAOX::app::MagAOXApp< _useINDI >::loopPause ( )
inherited

Get the loop pause time.

Returns
the value of m_loopPause

Definition at line 3808 of file MagAOXApp.hpp.

◆ newCallBack_clearFSMAlert()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::newCallBack_clearFSMAlert ( const pcf::IndiProperty &  ipRecv)
protectedinherited

The callback called by the static version, to actually process the FSM Alert Clear request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the new property request.

Definition at line 3641 of file MagAOXApp.hpp.

References INDI_IDLE, and MagAOX::app::ipRecv.

◆ newCallBack_cropMode()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_cropMode ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW cropMode request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 849 of file stdCamera.hpp.

◆ newCallBack_emgain()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_emgain ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW EM gain request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 753 of file stdCamera.hpp.

◆ newCallBack_exptime()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_exptime ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW exposure time request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 773 of file stdCamera.hpp.

◆ newCallBack_fps()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_fps ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW fps request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 793 of file stdCamera.hpp.

◆ newCallBack_mode()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_mode ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW mode request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 821 of file stdCamera.hpp.

◆ newCallBack_readoutSpeed()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_readoutSpeed ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW readout speed request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 713 of file stdCamera.hpp.

◆ newCallBack_reconfigure()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_reconfigure ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW reconfigure request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 829 of file stdCamera.hpp.

◆ newCallBack_roi_bin_x()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_bin_x ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW bin_x request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 889 of file stdCamera.hpp.

◆ newCallBack_roi_bin_y()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_bin_y ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW bin_y request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 897 of file stdCamera.hpp.

◆ newCallBack_roi_check()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_check ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_check request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 917 of file stdCamera.hpp.

◆ newCallBack_roi_default()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_default ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_default request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 977 of file stdCamera.hpp.

◆ newCallBack_roi_full()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_full ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_full request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 945 of file stdCamera.hpp.

◆ newCallBack_roi_fullbin()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_fullbin ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_fullbin request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 953 of file stdCamera.hpp.

◆ newCallBack_roi_h()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_h ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_h request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 881 of file stdCamera.hpp.

◆ newCallBack_roi_last()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_last ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_last request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 969 of file stdCamera.hpp.

◆ newCallBack_roi_loadlast()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_loadlast ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_loadlast request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 961 of file stdCamera.hpp.

◆ newCallBack_roi_set()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_set ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_set request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 937 of file stdCamera.hpp.

◆ newCallBack_roi_w()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_w ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_w request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 873 of file stdCamera.hpp.

◆ newCallBack_roi_x()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_x ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_x request.

Returns
0 on success.
-1 on error.
Todo:
why don't these check if usesROI is true?
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 857 of file stdCamera.hpp.

◆ newCallBack_roi_y()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_roi_y ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW roi_y request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 865 of file stdCamera.hpp.

◆ newCallBack_shutter()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_shutter ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW shutter request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 997 of file stdCamera.hpp.

◆ newCallBack_stdCamera()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_stdCamera ( const pcf::IndiProperty &  ipRecv)
inherited

The callback function for stdCamera properties.

Dispatches to the relevant handler

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 653 of file stdCamera.hpp.

◆ newCallBack_synchro()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_synchro ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW synchro request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 813 of file stdCamera.hpp.

◆ newCallBack_temp()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_temp ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW CCD temp request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 673 of file stdCamera.hpp.

◆ newCallBack_temp_controller()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_temp_controller ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW CCD temp control request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 693 of file stdCamera.hpp.

◆ newCallBack_vShiftSpeed()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::newCallBack_vShiftSpeed ( const pcf::IndiProperty &  ipRecv)
inherited

Callback to process a NEW vshift speed request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 733 of file stdCamera.hpp.

◆ onPowerOff()

◆ open()

Open the shutter.

Do not lock the mutex before calling this.

Returns
0 on success
-1 on error
Todo:
need shutter log types

Definition at line 164 of file dssShutter.hpp.

◆ openThreadExec()

void MagAOX::app::dev::dssShutter< ocam2KCtrl >::openThreadExec ( )
protectedinherited

Open thread function.

Runs until m_shutdown is true.

Definition at line 202 of file dssShutter.hpp.

◆ openThreadStart()

void MagAOX::app::dev::dssShutter< ocam2KCtrl >::openThreadStart ( dssShutter< ocam2KCtrl > *  d)
staticprotectedinherited

Open thread starter function.

Parameters
[in]dpointer to this

Definition at line 197 of file dssShutter.hpp.

◆ pdvAcquire()

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::pdvAcquire ( timespec &  currImageTimestamp)
inherited

Definition at line 196 of file edtCamera.hpp.

◆ pdvConfig()

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::pdvConfig ( std::string &  cfgname)
inherited

Configure the EDT framegrabber.

Parameters
[in]cfgnameThe configuration name for the mode to set

Definition at line 105 of file edtCamera.hpp.

◆ pdvReconfig()

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::pdvReconfig ( )
inherited

Definition at line 198 of file edtCamera.hpp.

◆ pdvSerialWriteRead()

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::pdvSerialWriteRead ( std::string &  response,
const std::string &  command 
)
inherited

Send a serial command over cameralink and retrieve the response.

Parameters
[out]responsethe response to the command from the device
[in]commandthe command to send to the device

Definition at line 100 of file edtCamera.hpp.

◆ pdvStartAcquisition()

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::pdvStartAcquisition ( )
inherited

Definition at line 194 of file edtCamera.hpp.

◆ powerOnDefaults()

int MagAOX::app::ocam2KCtrl::powerOnDefaults ( )
inline

Set defaults for a power on state.

Returns
0 on success
-1 on error

Definition at line 808 of file ocam2KCtrl.hpp.

References MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_tempControlStatus, and MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_tempControlStatusSet.

◆ powerOnWaitElapsed()

template<bool _useINDI>
bool MagAOX::app::MagAOXApp< _useINDI >::powerOnWaitElapsed ( )
protectedinherited

This method tests whether the power on wait time has elapsed.

You would call this once per appLogic loop while in state POWERON. While false, you would return 0. Once it becomes true, take post-power-on actions and go on with life.

Returns
true if the time since POWERON is greater than the power-on wait, or if power management is not enabled
false otherwise

Definition at line 3674 of file MagAOXApp.hpp.

Referenced by MagAOX::app::picoMotorCtrl::appLogic(), MagAOX::app::smc100ccCtrl::appLogic(), and MagAOX::app::xt1121Ctrl::appLogic().

◆ powerState()

◆ powerStateTarget()

◆ reconfig()

int MagAOX::app::ocam2KCtrl::reconfig ( )
inline

Implementation of the framegrabber reconfig interface.

Locks the INDI mutex and calls edtCamera::pdvReconfig.

Returns
0 on success
-1 on error

Definition at line 1441 of file ocam2KCtrl.hpp.

References MagAOX::app::lock(), MagAOX::app::MagAOXApp< _useINDI >::log(), MagAOX::app::MagAOXApp< _useINDI >::m_indiMutex, MagAOX::app::stateCodes::READY, and MagAOX::app::MagAOXApp< _useINDI >::state().

◆ recordCamera()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::recordCamera ( bool  force = false)
inherited

Definition at line 1039 of file stdCamera.hpp.

◆ recordFGTimings()

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::recordFGTimings ( bool  force = false)
inherited

Definition at line 296 of file frameGrabber.hpp.

◆ recordTelem() [1/3]

int MagAOX::app::ocam2KCtrl::recordTelem ( const ocam_temps )
inline

Definition at line 1523 of file ocam2KCtrl.hpp.

References recordTemps().

◆ recordTelem() [2/3]

int MagAOX::app::ocam2KCtrl::recordTelem ( const telem_fgtimings )
inline

◆ recordTelem() [3/3]

int MagAOX::app::ocam2KCtrl::recordTelem ( const telem_stdcam )
inline

◆ recordTemps()

int MagAOX::app::ocam2KCtrl::recordTemps ( bool  force = false)
inline

Definition at line 1541 of file ocam2KCtrl.hpp.

Referenced by getTemps(), and recordTelem().

◆ registerIndiPropertyNew() [1/3]

template<bool _useINDI = true>
int MagAOX::app::MagAOXApp< _useINDI >::registerIndiPropertyNew ( pcf::IndiProperty &  prop,
const std::string &  propName,
const pcf::IndiProperty::Type &  propType,
const pcf::IndiProperty::PropertyPermType &  propPerm,
const pcf::IndiProperty::PropertyStateType &  propState,
const pcf::IndiProperty::SwitchRuleType &  propRule,
int(*)(void *, const pcf::IndiProperty &)   
)
inherited

Register an INDI property which is exposed for others to request a New Property for, with a switch rule.

This verison sets up the INDI property according to the arguments.

Returns
0 on success.
-1 on error.
Parameters
[out]propthe property to register
[in]propNamethe name of the property
[in]propTypethe type of the property
[in]propPermthe permissions of the property
[in]propStatethe state of the property
[in]propRulethe switch rule type

◆ registerIndiPropertyNew() [2/3]

template<bool _useINDI = true>
int MagAOX::app::MagAOXApp< _useINDI >::registerIndiPropertyNew ( pcf::IndiProperty &  prop,
const std::string &  propName,
const pcf::IndiProperty::Type &  propType,
const pcf::IndiProperty::PropertyPermType &  propPerm,
const pcf::IndiProperty::PropertyStateType &  propState,
int(*)(void *, const pcf::IndiProperty &)   
)
inherited

Register an INDI property which is exposed for others to request a New Property for.

This verison sets up the INDI property according to the arguments.

Returns
0 on success.
-1 on error.
Parameters
[out]propthe property to register
[in]propNamethe name of the property
[in]propTypethe type of the property
[in]propPermthe permissions of the property
[in]propStatethe state of the property

◆ registerIndiPropertyNew() [3/3]

template<bool _useINDI = true>
int MagAOX::app::MagAOXApp< _useINDI >::registerIndiPropertyNew ( pcf::IndiProperty &  prop,
int(*)(void *, const pcf::IndiProperty &)   
)
inherited

Register an INDI property which is exposed for others to request a New Property for.

In this version the supplied IndiProperty must be fully set up before passing in.

Returns
0 on success.
-1 on error.
Parameters
[in]propthe property to register, must be fully set up

Referenced by MagAOX::app::filterWheelCtrl::appStartup(), MagAOX::app::magAOXMaths::appStartup(), appStartup(), MagAOX::app::picoMotorCtrl::appStartup(), MagAOX::app::siglentSDG::appStartup(), MagAOX::app::streamWriter::appStartup(), MagAOX::app::sysMonitor::appStartup(), MagAOX::app::zaberCtrl::appStartup(), and libXWCTest::appTest::MagAOXAppTest::SCENARIO().

◆ registerIndiPropertyReadOnly() [1/2]

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::registerIndiPropertyReadOnly ( pcf::IndiProperty &  prop)
inherited

Register an INDI property which is read only.

This version requires the property be fully set up.

Returns
0 on success.
-1 on error.
Parameters
[in]propthe property to register, must be completely setup

Definition at line 2926 of file MagAOXApp.hpp.

Referenced by MagAOX::app::picamCtrl::appStartup(), and MagAOX::app::zaberCtrl::appStartup().

◆ registerIndiPropertyReadOnly() [2/2]

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::registerIndiPropertyReadOnly ( pcf::IndiProperty &  prop,
const std::string &  propName,
const pcf::IndiProperty::Type &  propType,
const pcf::IndiProperty::PropertyPermType &  propPerm,
const pcf::IndiProperty::PropertyStateType &  propState 
)
inherited

Register an INDI property which is read only.

This verison sets up the INDI property according to the arguments.

Returns
0 on success.
-1 on error.
Parameters
[out]propthe property to register, will be configured
[in]propNamethe name of the property
[in]propTypethe type of the property
[in]propPermthe permissions of the property
[in]propStatethe state of the property

Definition at line 2955 of file MagAOXApp.hpp.

◆ registerIndiPropertySet()

template<bool _useINDI = true>
int MagAOX::app::MagAOXApp< _useINDI >::registerIndiPropertySet ( pcf::IndiProperty &  prop,
const std::string &  devName,
const std::string &  propName,
int(*)(void *, const pcf::IndiProperty &)   
)
inherited

Register an INDI property which is monitored for updates from others.

Returns
0 on success.
-1 on error.
Parameters
[out]propthe property to register
[in]devNamethe device which owns this property
[in]propNamethe name of the property

Definition at line 3063 of file MagAOXApp.hpp.

◆ resetEMProtection()

◆ secretsPath()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::secretsPath ( )
inherited

Get the secrets path.

Returns
the value of m_secretsPath

Definition at line 3796 of file MagAOXApp.hpp.

◆ sendGetPropertySetList()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::sendGetPropertySetList ( bool  all = false)
inherited

Definition at line 3222 of file MagAOXApp.hpp.

References MagAOX::app::it.

◆ sendNewProperty() [1/2]

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::sendNewProperty ( const pcf::IndiProperty &  ipSend)
protectedinherited

Send a newProperty command to another device (using the INDI Client interface)

Returns
0 on success.
-1 on an error, which will be logged
Parameters
[in]ipSendThe property to send a "new" INDI command for

Definition at line 3577 of file MagAOXApp.hpp.

◆ sendNewProperty() [2/2]

template<bool _useINDI>
template<typename T >
int MagAOX::app::MagAOXApp< _useINDI >::sendNewProperty ( const pcf::IndiProperty &  ipSend,
const std::string &  el,
const T &  newVal 
)
protectedinherited

Send a newProperty command to another device (using the INDI Client interface)

Copies the input IndiProperty, then updates the element with the new value.

Returns
0 on success.
-1 on an errory.
Parameters
[in]ipSendThe property to send a "new" INDI command for
[in]elThe element of the property to change
[in]newValThe value to request for the element.

Definition at line 3541 of file MagAOXApp.hpp.

References MagAOX::app::MagAOXApp< _useINDI >::sendNewProperty().

Referenced by MagAOX::app::ttmModulator::modTTM(), MagAOX::app::zaberCtrl::moveTo(), MagAOX::app::ttmModulator::offset12(), MagAOX::app::ttmModulator::offsetXY(), MagAOX::app::ttmModulator::restTTM(), MagAOX::app::MagAOXApp< _useINDI >::sendNewProperty(), setFPS(), MagAOX::app::ttmModulator::setTTM(), MagAOX::app::zaberCtrl::startHoming(), MagAOX::app::zaberCtrl::stop(), MagAOX::app::xt1121DCDU::turnOutletOff(), and MagAOX::app::xt1121DCDU::turnOutletOn().

◆ sendNewStandardIndiToggle()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::sendNewStandardIndiToggle ( const std::string &  device,
const std::string &  property,
bool  onoff 
)
protectedinherited

Send a new property commmand for a standard toggle switch.

Returns
0 on success
-1 on an error, which will be logged.
Parameters
[in]deviceThe device name
[in]propertyThe property name
[in]onoffSwitch state to send: true = on, false = off

Definition at line 3598 of file MagAOXApp.hpp.

◆ setCallBack_powerChannel()

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::setCallBack_powerChannel ( const pcf::IndiProperty &  ipRecv)
inherited

The callback called by the static version, to actually process the new request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 251 of file dssShutter.hpp.

◆ setCallBack_sensorChannel()

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::setCallBack_sensorChannel ( const pcf::IndiProperty &  ipRecv)
inherited

The callback called by the static version, to actually process the new request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 268 of file dssShutter.hpp.

◆ setCallBack_triggerChannel()

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::setCallBack_triggerChannel ( const pcf::IndiProperty &  ipRecv)
inherited

The callback called by the static version, to actually process the new request.

Returns
0 on success.
-1 on error.
Parameters
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 284 of file dssShutter.hpp.

◆ setCropMode() [1/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setCropMode ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setCropMode when the derivedT does not have crop mode.

Tag-dispatch resolution of c_stdCamera_cropMode==false will call this function. This prevents requiring derivedT to have its own setCropMode().

Definition at line 842 of file stdCamera.hpp.

◆ setCropMode() [2/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setCropMode ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setCropMode when the derivedT has crop mode.

Tag-dispatch resolution of c_stdCamera_cropMode==true will call this function. Calls derivedT::setCropMode.

Definition at line 836 of file stdCamera.hpp.

◆ setDefaults()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::setDefaults ( int  argc,
char **  argv 
)
virtualinherited

Set the paths for config files.

Replaces the mx::application defaults with the MagAO-X config system.

This function parses the CL for "-n" or "--name".

Do not override this unless you intend to depart from the MagAO-X standard.

Parameters
[in]argcstandard command line result specifying number of arguments in argv
[in]argvstandard command line result containing the arguments.

Definition at line 1331 of file MagAOXApp.hpp.

References MAGAOX_calibRelPath, MAGAOX_configRelPath, MAGAOX_env_calib, MAGAOX_env_config, MAGAOX_env_cpuset, MAGAOX_env_log, MAGAOX_env_path, MAGAOX_env_secrets, MAGAOX_env_sys, MAGAOX_logRelPath, MAGAOX_path, MAGAOX_secretsRelPath, and MAGAOX_sysRelPath.

◆ setEMGain() [1/3]

◆ setEMGain() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setEMGain ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setEMGain when the derivedT does not have EM Gain.

Tag-dispatch resolution of c_stdCamera_emGain==false will call this function. This prevents requiring derivedT to have its own setEMGain().

Definition at line 746 of file stdCamera.hpp.

◆ setEMGain() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setEMGain ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setEMGain when the derivedT has EM Gain.

Tag-dispatch resolution of c_stdCamera_emGain==true will call this function. Calls derivedT::setEMGain.

Definition at line 740 of file stdCamera.hpp.

◆ setEuidCalled()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::setEuidCalled ( )
privateinherited

Set the effective user ID to the called value, i.e. the highest possible.

If setuid is set on the file, this will be super-user privileges.

Reference: http://pubs.opengroup.org/onlinepubs/009695399/functions/seteuid.html

Returns
0 on success
-1 on error from setuid().

Definition at line 2209 of file MagAOXApp.hpp.

Referenced by MagAOX::app::MagAOXApp< _useINDI >::elevatedPrivileges::elevate().

◆ setEuidReal()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::setEuidReal ( )
privateinherited

Set the effective user ID to the real value, i.e. the file owner.

Reference: http://pubs.opengroup.org/onlinepubs/009695399/functions/seteuid.html

Returns
0 on success
-1 on error from setuid().

Definition at line 2227 of file MagAOXApp.hpp.

Referenced by MagAOX::app::MagAOXApp< _useINDI >::elevatedPrivileges::restore().

◆ setExpTime() [1/3]

int MagAOX::app::ocam2KCtrl::setExpTime ( )
inline

Required by stdCamera, but this does not do anything for this camera [stdCamera interface].

Returns
0 always

Definition at line 1038 of file ocam2KCtrl.hpp.

◆ setExpTime() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setExpTime ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setExptime when the derivedT does not use exposure time controls.

Tag-dispatch resolution of c_stdCamera_exptimeCtrl==false will call this function. This prevents requiring derivedT to have its own setExpTime().

Definition at line 766 of file stdCamera.hpp.

◆ setExpTime() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setExpTime ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setExpTime when the derivedT uses exposure time controls.

Tag-dispatch resolution of c_stdCamera_exptimeCtrl==true will call this function. Calls derivedT::setExpTime.

Definition at line 760 of file stdCamera.hpp.

◆ setFPS() [1/3]

◆ setFPS() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setFPS ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setFPS when the derivedT does not use FPS controls.

Tag-dispatch resolution of c_stdCamera_hasFPS==false will call this function. This prevents requiring derivedT to have its own setFPS().

Definition at line 786 of file stdCamera.hpp.

◆ setFPS() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setFPS ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setFPS when the derivedT uses FPS controls.

Tag-dispatch resolution of c_stdCamera_fpsCtrl==true will call this function. Calls derivedT::setFPS.

Definition at line 780 of file stdCamera.hpp.

◆ setNextROI() [1/3]

int MagAOX::app::ocam2KCtrl::setNextROI ( )
inline

Required by stdCamera, but this does not do anything for this camera [stdCamera interface].

Returns
0 always

Definition at line 1044 of file ocam2KCtrl.hpp.

◆ setNextROI() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setNextROI ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setNextROI when the derivedT does not use ROIs.

Tag-dispatch resolution of c_stdCamera_usesROI==false will call this function. This prevents requiring derivedT to have its own setNextROI().

Definition at line 930 of file stdCamera.hpp.

◆ setNextROI() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setNextROI ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setNextROI when the derivedT uses ROIs.

Tag-dispatch resolution of c_stdCamera_usesROI==true will call this function. Calls derivedT::setNextROI.

Definition at line 924 of file stdCamera.hpp.

◆ setReadoutSpeed() [1/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setReadoutSpeed ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setReadoutSpeed when the derivedT does not have readout speed control.

Tag-dispatch resolution of c_stdCamera_readoutSpeed==false will call this function. Just returns 0.

Definition at line 706 of file stdCamera.hpp.

◆ setReadoutSpeed() [2/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setReadoutSpeed ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setReadoutSpeed when the derivedT has readout speed control.

Tag-dispatch resolution of c_stdCamera_readoutSpeed==true will call this function. Calls derivedT::setReadoutSpeed.

Definition at line 700 of file stdCamera.hpp.

◆ setShutter() [1/3]

int MagAOX::app::ocam2KCtrl::setShutter ( int  sh)
inline

Sets the shutter state, via call to dssShutter::setShutterState(int) [stdCamera interface].

Returns
0 always

Definition at line 1050 of file ocam2KCtrl.hpp.

References MagAOX::app::MagAOXApp< _useINDI >::log().

◆ setShutter() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setShutter ( int  ss,
const mx::meta::trueFalseT< false > &  f 
)
inherited

Interface to setShutter when the derivedT does not have a shutter.

Tag-dispatch resolution of c_stdCamera_hasShutter==false will call this function. This prevents requiring derivedT to have its own setShutter().

Definition at line 990 of file stdCamera.hpp.

◆ setShutter() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setShutter ( int  ss,
const mx::meta::trueFalseT< true > &  t 
)
inherited

Interface to setShutter when the derivedT has a shutter.

Tag-dispatch resolution of c_stdCamera_hasShutter==true will call this function. Calls derivedT::setShutter.

Definition at line 984 of file stdCamera.hpp.

◆ setShutterState()

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::setShutterState ( int  sh)
inherited

Change shutter state.

Sets m_doOpen or m_doShut and signals the appropriate thread.

Returns
0 on success
-1 on error
Parameters
shDesired shutter state. 0 for shut,1 for open

Definition at line 156 of file dssShutter.hpp.

◆ setSigTermHandler()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::setSigTermHandler ( )
privateinherited

Sets the handler for SIGTERM, SIGQUIT, and SIGINT.

Definition at line 2098 of file MagAOXApp.hpp.

References flatlogs::logPrio::LOG_DEBUG.

◆ setSynchro() [1/3]

◆ setSynchro() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setSynchro ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setSynchro when the derivedT does not have synchronization.

Tag-dispatch resolution of c_stdCamera_ynchro==false will call this function. This prevents requiring derivedT to have its own setSynchro().

Definition at line 806 of file stdCamera.hpp.

◆ setSynchro() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setSynchro ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setSynchro when the derivedT has synchronization.

Tag-dispatch resolution of c_stdCamera_synchro==true will call this function. Calls derivedT::setSynchro.

Definition at line 800 of file stdCamera.hpp.

◆ setTempControl() [1/3]

◆ setTempControl() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setTempControl ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setTempControl when the derivedT does not have temperature control.

Tag-dispatch resolution of c_stdCamera_tempControl==false will call this function. Prevents requiring derivedT::setTempControl.

Definition at line 686 of file stdCamera.hpp.

◆ setTempControl() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setTempControl ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setTempControl when the derivedT has temperature control.

Tag-dispatch resolution of c_stdCamera_tempControl==true will call this function. Calls derivedT::setTempControl.

Definition at line 680 of file stdCamera.hpp.

◆ setTempSetPt() [1/3]

int MagAOX::app::ocam2KCtrl::setTempSetPt ( )
inline

◆ setTempSetPt() [2/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setTempSetPt ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setTempSetPt when the derivedT does not have temperature control.

Tag-dispatch resolution of c_stdCamera_tempControl==false will call this function. Prevents requiring derivedT::setTempSetPt.

Definition at line 666 of file stdCamera.hpp.

◆ setTempSetPt() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setTempSetPt ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setTempSetPt when the derivedT has temperature control.

Tag-dispatch resolution of c_stdCamera_tempControl==true will call this function. Calls derivedT::setTempSetPt.

Definition at line 660 of file stdCamera.hpp.

◆ setupBasicConfig()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::setupBasicConfig ( )
virtualinherited

The basic MagAO-X configuration setup method. Should not normally be overridden.

This method sets up the config system with the standard MagAO-X key=value pairs.

Though it is virtual, it should not normally be overridden unless you need to depart from the MagAO-X standard.

Setting up app specific config goes in setupConfig() implemented in the derived class.

Definition at line 1448 of file MagAOXApp.hpp.

◆ setupConfig() [1/6]

◆ setupConfig() [2/6]

int MagAOX::app::dev::telemeter< ocam2KCtrl >::setupConfig ( appConfigurator &  config)
inherited

Setup an application configurator for the device section.

Returns
0 on success.
-1 on error (nothing implemented yet)
Parameters
[in]configan application configuration to setup

Definition at line 112 of file telemeter.hpp.

◆ setupConfig() [3/6]

void MagAOX::app::dev::dssShutter< ocam2KCtrl >::setupConfig ( mx::app::appConfigurator &  config)
inherited

Setup the configuration system.

This should be called in derivedT::setupConfig as

dssShutter<derivedT>::setupConfig(config);

with appropriate error checking.

Parameters
[out]configthe derived classes configurator

Definition at line 78 of file dssShutter.hpp.

◆ setupConfig() [4/6]

void MagAOX::app::dev::edtCamera< ocam2KCtrl >::setupConfig ( mx::app::appConfigurator &  config)
inherited

Setup the configuration system.

This should be called in derivedT::setupConfig as

edtCamera<derivedT>::setupConfig(config);

with appropriate error checking.

Parameters
[out]configthe derived classes configurator

Definition at line 115 of file edtCamera.hpp.

◆ setupConfig() [5/6]

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::setupConfig ( mx::app::appConfigurator &  config)
inherited

Setup the configuration system.

This should be called in derivedT::setupConfig as

framegrabber<derivedT>::setupConfig(config);

with appropriate error checking.

Parameters
[out]configthe derived classes configurator

Definition at line 180 of file frameGrabber.hpp.

◆ setupConfig() [6/6]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setupConfig ( mx::app::appConfigurator &  config)
inherited

Setup the configuration system.

This should be called in derivedT::setupConfig as

stdCamera<derivedT>::setupConfig(config);

with appropriate error checking.

Parameters
[out]configthe derived classes configurator

Definition at line 535 of file stdCamera.hpp.

◆ setVShiftSpeed() [1/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setVShiftSpeed ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to setVShiftSpeed when the derivedT does not have vshift speed control.

Tag-dispatch resolution of c_stdCamera_vShiftSpeed==false will call this function. Just returns 0.

Definition at line 726 of file stdCamera.hpp.

◆ setVShiftSpeed() [2/2]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::setVShiftSpeed ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to setVShiftSpeed when the derivedT has vshift speed control.

Tag-dispatch resolution of c_stdCamera_vShiftSpeed==true will call this function. Calls derivedT::setVShiftSpeed.

Definition at line 720 of file stdCamera.hpp.

◆ shut()

Shut the shutter.

Do not lock the mutex before calling this.

Returns
0 on success
-1 on error
Todo:
need shutter log types
Todo:
need shutter log types

Definition at line 172 of file dssShutter.hpp.

◆ shutdown()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::shutdown ( )
inherited

Get the value of the shutdown flag.

Returns
the current value of m_shutdown

Definition at line 3814 of file MagAOXApp.hpp.

Referenced by MagAOX::app::streamWriter::swThreadExec().

◆ shutThreadExec()

void MagAOX::app::dev::dssShutter< ocam2KCtrl >::shutThreadExec ( )
protectedinherited

Shut thread function.

Runs until m_shutdown is true.

Definition at line 220 of file dssShutter.hpp.

◆ shutThreadStart()

void MagAOX::app::dev::dssShutter< ocam2KCtrl >::shutThreadStart ( dssShutter< ocam2KCtrl > *  d)
staticprotectedinherited

Shut thread starter function.

Parameters
[in]dpointer to this

Definition at line 215 of file dssShutter.hpp.

◆ st_newCallBack_clearFSMAlert()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::st_newCallBack_clearFSMAlert ( void app,
const pcf::IndiProperty &  ipRecv 
)
staticprotectedinherited

The static callback function to be registered for requesting to clear the FSM alert.

Returns
0 on success.
-1 on error.
Parameters
[in]appa pointer to this, will be static_cast-ed to MagAOXApp.
[in]ipRecvthe INDI property sent with the new property request.

Definition at line 3635 of file MagAOXApp.hpp.

References MagAOX::app::ipRecv.

◆ st_newCallBack_stdCamera()

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::st_newCallBack_stdCamera ( void *  app,
const pcf::IndiProperty &  ipRecv 
)
staticinherited

The static callback function to be registered for stdCamera properties.

Calls newCallback_stdCamera

Returns
0 on success.
-1 on error.
Parameters
[in]appa pointer to this, will be static_cast-ed to derivedT.
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 642 of file stdCamera.hpp.

◆ st_setCallBack_powerChannel()

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::st_setCallBack_powerChannel ( void *  app,
const pcf::IndiProperty &  ipRecv 
)
staticinherited

The static callback function to be registered for shutter power channel changes.

Returns
0 on success.
-1 on error.
Parameters
[in]appa pointer to this, will be static_cast-ed to derivedT.
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 242 of file dssShutter.hpp.

◆ st_setCallBack_sensorChannel()

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::st_setCallBack_sensorChannel ( void *  app,
const pcf::IndiProperty &  ipRecv 
)
staticinherited

The static callback function to be registered for shutter sensor channel changes.

Returns
0 on success.
-1 on error.
Parameters
[in]appa pointer to this, will be static_cast-ed to derivedT.
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 259 of file dssShutter.hpp.

◆ st_setCallBack_triggerChannel()

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::st_setCallBack_triggerChannel ( void *  app,
const pcf::IndiProperty &  ipRecv 
)
staticinherited

The static callback function to be registered for shutter trigger channel changes.

Returns
0 on success.
-1 on error.
Parameters
[in]appa pointer to this, will be static_cast-ed to derivedT.
[in]ipRecvthe INDI property sent with the the new property request.

Definition at line 275 of file dssShutter.hpp.

◆ startAcquisition()

int MagAOX::app::ocam2KCtrl::startAcquisition ( )
inline

Implementation of the framegrabber startAcquisition interface.

Initializes m_lastImageNumber, and calls edtCamera::pdvStartAcquisition

Returns
0 on success
-1 on error

Definition at line 1330 of file ocam2KCtrl.hpp.

References MagAOX::app::MagAOXApp< _useINDI >::log(), and m_lastImageNumber.

◆ startINDI()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::startINDI ( )
protectedinherited

Start INDI Communications.

Returns
0 on success
-1 on error. This is fatal.

Definition at line 3165 of file MagAOXApp.hpp.

◆ state() [1/2]

template<bool _useINDI>
stateCodes::stateCodeT MagAOX::app::MagAOXApp< _useINDI >::state ( )
inherited

Get the current state code.

Returns
m_state

Definition at line 2539 of file MagAOXApp.hpp.

Referenced by MagAOX::app::baslerCtrl::acquireAndCheckValid(), MagAOX::app::picamCtrl::acquireAndCheckValid(), MagAOX::app::qhyCtrl::acquireAndCheckValid(), MagAOX::app::acronameUsbHub::appLogic(), MagAOX::app::andorCtrl::appLogic(), MagAOX::app::baslerCtrl::appLogic(), MagAOX::app::cameraSim::appLogic(), MagAOX::app::filterWheelCtrl::appLogic(), MagAOX::app::hsfwCtrl::appLogic(), appLogic(), MagAOX::app::picamCtrl::appLogic(), MagAOX::app::picoMotorCtrl::appLogic(), MagAOX::app::siglentSDG::appLogic(), MagAOX::app::smc100ccCtrl::appLogic(), MagAOX::app::streamWriter::appLogic(), MagAOX::app::trippLitePDU::appLogic(), MagAOX::app::ttmModulator::appLogic(), MagAOX::app::xt1121Ctrl::appLogic(), MagAOX::app::xt1121DCDU::appLogic(), MagAOX::app::zaberCtrl::appLogic(), MagAOX::app::zylaCtrl::appLogic(), MagAOX::app::acronameUsbHub::appStartup(), MagAOX::app::andorCtrl::appStartup(), MagAOX::app::baslerCtrl::appStartup(), MagAOX::app::cameraSim::appStartup(), MagAOX::app::filterWheelCtrl::appStartup(), MagAOX::app::hsfwCtrl::appStartup(), MagAOX::app::magAOXMaths::appStartup(), MagAOX::app::qhyCtrl::appStartup(), MagAOX::app::smc100ccCtrl::appStartup(), MagAOX::app::sysMonitor::appStartup(), MagAOX::app::trippLitePDU::appStartup(), MagAOX::app::xt1121DCDU::appStartup(), MagAOX::app::zylaCtrl::appStartup(), MagAOX::app::andorCtrl::cameraSelect(), MagAOX::app::siglentSDG::changeAmp(), MagAOX::app::siglentSDG::changeFreq(), MagAOX::app::siglentSDG::changeOfst(), MagAOX::app::siglentSDG::changeOutp(), MagAOX::app::siglentSDG::changePhse(), MagAOX::app::siglentSDG::changeSync(), MagAOX::app::siglentSDG::changeWdth(), MagAOX::app::siglentSDG::changeWvtp(), MagAOX::app::picoMotorCtrl::channelThreadExec(), MagAOX::app::siglentSDG::checkSetup(), MagAOX::app::andorCtrl::configureAcquisition(), MagAOX::app::baslerCtrl::configureAcquisition(), MagAOX::app::cameraSim::configureAcquisition(), configureAcquisition(), MagAOX::app::picamCtrl::configureAcquisition(), MagAOX::app::qhyCtrl::configureAcquisition(), MagAOX::app::baslerCtrl::connect(), MagAOX::app::picamCtrl::connect(), MagAOX::app::qhyCtrl::connect(), MagAOX::app::picamCtrl::getAcquisitionState(), MagAOX::app::smc100ccCtrl::getCtrlState(), MagAOX::app::baslerCtrl::getExpTime(), MagAOX::app::qhyCtrl::getExpTime(), MagAOX::app::baslerCtrl::getFPS(), MagAOX::app::baslerCtrl::getTemp(), MagAOX::app::qhyCtrl::getTemp(), MagAOX::app::picamCtrl::getTemps(), MagAOX::app::filterWheelCtrl::home(), MagAOX::app::baslerCtrl::loadImageIntoStream(), MagAOX::app::qhyCtrl::loadImageIntoStream(), MagAOX::app::hsfwCtrl::moveTo(), MagAOX::app::smc100ccCtrl::moveTo(), MagAOX::app::siglentSDG::queryBTWV(), MagAOX::app::siglentSDG::queryMDWV(), MagAOX::app::siglentSDG::querySWWV(), MagAOX::app::andorCtrl::reconfig(), reconfig(), MagAOX::app::picamCtrl::reconfig(), MagAOX::app::streamWriter::recordSavingState(), MagAOX::app::andorCtrl::setCropMode(), MagAOX::app::picamCtrl::setEMGain(), MagAOX::app::andorCtrl::setExpTime(), MagAOX::app::picamCtrl::setExpTime(), MagAOX::app::andorCtrl::setNextROI(), MagAOX::app::qhyCtrl::setNextROI(), MagAOX::app::andorCtrl::setReadoutSpeed(), MagAOX::app::andorCtrl::setShutter(), MagAOX::app::andorCtrl::setVShiftSpeed(), MagAOX::app::andorCtrl::startAcquisition(), MagAOX::app::baslerCtrl::startAcquisition(), MagAOX::app::cameraSim::startAcquisition(), MagAOX::app::qhyCtrl::startAcquisition(), MagAOX::app::hsfwCtrl::startHoming(), stateStringValid(), MagAOX::app::streamWriter::swThreadExec(), MagAOX::app::acronameUsbHub::updateOutletState(), MagAOX::app::trippLitePDU::updateOutletStates(), and MagAOX::app::siglentSDG::writeRead().

◆ state() [2/2]

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::state ( const stateCodes::stateCodeT s,
bool  stateAlert = false 
)
inherited

Set the current state code.

Todo:
move this to a function in stateCodes
Parameters
[in]sThe new application state
[in]stateAlert[optional] flag to set the alert state of the FSM property.

Definition at line 2545 of file MagAOXApp.hpp.

References INDI_ALERT, INDI_BUSY, INDI_IDLE, INDI_OK, MagAOX::app::lock(), flatlogs::logPrio::LOG_CRITICAL, flatlogs::logPrio::LOG_ERROR, flatlogs::logPrio::LOG_INFO, and flatlogs::logPrio::LOG_WARNING.

◆ stateAlert()

template<bool _useINDI>
bool MagAOX::app::MagAOXApp< _useINDI >::stateAlert ( )
inherited

Get the value of the state alert flag.

Returns
the current value of m_stateAlert

Definition at line 2603 of file MagAOXApp.hpp.

◆ stateLogged()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::stateLogged ( )
inherited

Updates and returns the value of m_stateLogged. Will be 0 on first call after a state change, >0 afterwards.

This method exists to facilitate logging the reason for a state change once, but not logging it on subsequent event loops. Returns the current value upon entry, but updates before returning so that the next call returns the incremented value. Example usage:

if( connection_failed ) //some condition set this to true
{
if(!stateLogged()) log<text_log>("Not connected");
}
stateCodes::stateCodeT state()
Get the current state code.
int stateLogged()
Updates and returns the value of m_stateLogged. Will be 0 on first call after a state change,...
static int log(const typename logT::messageT &msg, logPrioT level=logPrio::LOG_DEFAULT)
Make a log entry.
@ NOTCONNECTED
The application is not connected to the device or service.

In this example, the log entry is made the first time the state changes. If there are no changes to a different state in the mean time, then when the event loop gets here again and decides it is not connected, the log entry will not be made.

Returns
current value of m_stateLogged, that is the value before it is incremented.

Definition at line 2615 of file MagAOXApp.hpp.

Referenced by MagAOX::app::acronameUsbHub::appLogic(), MagAOX::app::filterWheelCtrl::appLogic(), MagAOX::app::hsfwCtrl::appLogic(), MagAOX::app::picoMotorCtrl::appLogic(), MagAOX::app::siglentSDG::appLogic(), MagAOX::app::smc100ccCtrl::appLogic(), MagAOX::app::trippLitePDU::appLogic(), MagAOX::app::ttmModulator::appLogic(), MagAOX::app::xt1121Ctrl::appLogic(), MagAOX::app::andorCtrl::cameraSelect(), MagAOX::app::baslerCtrl::connect(), MagAOX::app::picamCtrl::connect(), and MagAOX::app::qhyCtrl::connect().

◆ stateString() [1/3]

◆ stateString() [2/3]

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::stateString ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to stateString when the derivedT does not provide it.

Tag-dispatch resolution of c_stdCamera_usesStateString==false will call this function. returns "".

Definition at line 1010 of file stdCamera.hpp.

◆ stateString() [3/3]

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::stateString ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to stateString when the derivedT provides it.

Tag-dispatch resolution of c_stdCamera_usesStateString==true will call this function. Calls derivedT::stateString.

Definition at line 1004 of file stdCamera.hpp.

◆ stateStringValid() [1/3]

◆ stateStringValid() [2/3]

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::stateStringValid ( const mx::meta::trueFalseT< false > &  f)
inherited

Interface to stateStringValid when the derivedT does not provide it.

Tag-dispatch resolution of c_stdCamera_usesStateString==false will call this function. returns false.

Definition at line 1022 of file stdCamera.hpp.

◆ stateStringValid() [3/3]

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::stateStringValid ( const mx::meta::trueFalseT< true > &  t)
inherited

Interface to stateStringValid when the derivedT provides it.

Tag-dispatch resolution of c_stdCamera_usesStateString==true will call this function. Calls derivedT::stateStringValid.

Definition at line 1016 of file stdCamera.hpp.

◆ sysPath()

template<bool _useINDI>
std::string MagAOX::app::MagAOXApp< _useINDI >::sysPath ( )
inherited

Get the system path.

Returns
the value of m_sysPath

Definition at line 3790 of file MagAOXApp.hpp.

◆ telem()

int MagAOX::app::dev::telemeter< ocam2KCtrl >::telem ( const typename telT::messageT &  msg)
inherited

Make a telemetry recording.

Wrapper for logManager::log, which updates telT::lastRecord.

Template Parameters
logTthe log entry type
retvalthe value returned by this method.
Parameters
[in]msgthe data to log

Definition at line 95 of file telemeter.hpp.

◆ threadStart()

template<bool _useINDI>
template<class thisPtr , class Function >
int MagAOX::app::MagAOXApp< _useINDI >::threadStart ( std::thread &  thrd,
bool thrdInit,
pid_t tpid,
pcf::IndiProperty &  thProp,
int  thrdPrio,
const std::string &  cpuset,
const std::string &  thrdName,
thisPtr thrdThis,
Function &&  thrdStart 
)
inherited

Start a thread, using this class's privileges to set priority, etc.

The thread initialization synchronizer bool is set to true at the beginning of this function, then is set to false once all initialization is complete. The thread exec function should wait until this is false before doing anything except setting the pid. This is to avoid privilege escalation bugs.

The interface of the thread start function is:

static void impl::myThreadStart( impl * o )
{
o->myThreadExec(); //A member function which actually executes the thread
}

where impl is the derived class, and mThreadStart and myThreadExec are members of impl.

Returns
0 on success
-1 on error
Parameters
[out]thrdThe thread object to start executing
thrdInit[in/out] The thread initilization synchronizer.
tpid[in/out] The thread pid to be filled in by thrdStart immediately upon call
thProp[in/out] The INDI property to publish the thread details
[in]thrdPrioThe r/t priority to set for this thread
[in]cpusetthe cpuset to place this thread on. Ignored if "".
[in]thrdNameThe name of the thread (just for logging)
[in]thrdThisThe this pointer to pass to the thread starter function
[in]thrdStartThe thread starting function, a static function taking a this pointer as argument.

Definition at line 2399 of file MagAOXApp.hpp.

References flatlogs::logPrio::LOG_NOTICE, and MAGAOX_RT_SCHED_POLICY.

Referenced by MagAOX::app::picoMotorCtrl::appStartup(), MagAOX::app::streamWriter::appStartup(), and MagAOX::app::sysMonitor::appStartup().

◆ unlockPID()

template<bool _useINDI>
int MagAOX::app::MagAOXApp< _useINDI >::unlockPID ( )
protectedinherited

Remove the PID file.

Definition at line 2373 of file MagAOXApp.hpp.

◆ updateIfChanged() [1/4]

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::updateIfChanged ( pcf::IndiProperty &  p,
const std::string &  el,
const char newVal,
pcf::IndiProperty::PropertyStateType  ipState = pcf::IndiProperty::Ok 
)
protectedinherited

Update an INDI property element value if it has changed.

Will only peform a SetProperty if the new element value has changed compared to the stored value, or if the property state has changed.

This comparison is done in the true type of the value.

This is a specialization for const char * to std::string.

For a property with multiple elements, you should use the vector version to minimize network traffic. This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Parameters
p[in/out] The property containing the element to possibly update
[in]elThe element name
[in]newValthe new value

Definition at line 3408 of file MagAOXApp.hpp.

◆ updateIfChanged() [2/4]

template<bool _useINDI>
template<typename T >
void MagAOX::app::MagAOXApp< _useINDI >::updateIfChanged ( pcf::IndiProperty &  p,
const std::string &  el,
const std::vector< T > &  newVals,
pcf::IndiProperty::PropertyStateType  ipState = pcf::IndiProperty::Ok 
)
protectedinherited

Update an INDI property if values have changed.

Will only peform a SetProperty if at least one value has changed compared to the stored value, or if the property state has changed.

Constructs the element names for each value as elX where X is the index of the vector.

This comparison is done in the true type of the value.

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Parameters
p[in/out] The property containing the element to possibly update
[in]elBeginning of each element name
[in]newValsthe new values
[in]ipState[optional] the new state

Definition at line 3433 of file MagAOXApp.hpp.

◆ updateIfChanged() [3/4]

template<bool _useINDI>
template<typename T >
void MagAOX::app::MagAOXApp< _useINDI >::updateIfChanged ( pcf::IndiProperty &  p,
const std::string &  el,
const T &  newVal,
pcf::IndiProperty::PropertyStateType  ipState = pcf::IndiProperty::Ok 
)
protectedinherited

Update an INDI property element value if it has changed.

Will only peform a SetProperty if the new element value has changed compared to the stored value, or if the property state has changed.

This comparison is done in the true type of the value.

For a property with multiple elements, you should use the vector version to minimize network traffic.

Parameters
p[in/out] The property containing the element to possibly update
[in]elThe element name
[in]newValthe new value

Definition at line 3393 of file MagAOXApp.hpp.

Referenced by MagAOX::app::filterWheelCtrl::appLogic(), appLogic(), MagAOX::app::picoMotorCtrl::appLogic(), MagAOX::app::smc100ccCtrl::appLogic(), MagAOX::app::ttmModulator::appLogic(), MagAOX::app::zaberCtrl::appLogic(), MagAOX::app::xt1121Ctrl::channelSetCallback(), MagAOX::app::baslerCtrl::checkNextROI(), MagAOX::app::cameraSim::checkNextROI(), MagAOX::app::andorCtrl::configureAcquisition(), MagAOX::app::baslerCtrl::configureAcquisition(), MagAOX::app::picamCtrl::configureAcquisition(), MagAOX::app::qhyCtrl::configureAcquisition(), MagAOX::app::zylaCtrl::configureAcquisition(), getEMGain(), MagAOX::app::xt1121Ctrl::getState(), getTemps(), MagAOX::app::INDI_NEWCALLBACK_DEFN(), MagAOX::app::smc100ccCtrl::moveTo(), MagAOX::app::filterWheelCtrl::moveToRaw(), MagAOX::app::acronameUsbHub::onPowerOff(), onPowerOff(), MagAOX::app::siglentSDG::onPowerOff(), MagAOX::app::xt1121Ctrl::onPowerOff(), MagAOX::app::siglentSDG::queryBSWV(), MagAOX::app::siglentSDG::queryOUTP(), resetEMProtection(), MagAOX::app::picamCtrl::setExpTime(), MagAOX::app::trippLitePDU::updateOutletStates(), MagAOX::app::magAOXMaths::updateVals(), and MagAOX::app::sysMonitor::updateVals().

◆ updateIfChanged() [4/4]

template<bool _useINDI>
template<typename T >
void MagAOX::app::MagAOXApp< _useINDI >::updateIfChanged ( pcf::IndiProperty &  p,
const std::vector< std::string > &  els,
const std::vector< T > &  newVals,
pcf::IndiProperty::PropertyStateType  newState = pcf::IndiProperty::Ok 
)
protectedinherited

Update an INDI property if values have changed.

Will only peform a SetProperty if at least one value has changed compared to the stored value, or if the property state has changed.

This comparison is done in the true type of the value.

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Parameters
p[in/out] The property containing the element to possibly update
[in]elsString vector of element names
[in]newValsthe new values
[in]newState[optional] The state of the property

Definition at line 3454 of file MagAOXApp.hpp.

◆ updateINDI() [1/3]

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::updateINDI ( )
inherited

The static callback function to be registered for the channel properties.

Returns
0 on success.
-1 on error. The callback called by the static version, to actually process the new request.
0 on success.
-1 on error. Update the INDI properties for this device controller You should call this once per main loop. It is not called automatically.
0 on success.
-1 on error.

Definition at line 235 of file edtCamera.hpp.

◆ updateINDI() [2/3]

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::updateINDI ( )
inherited

Update the INDI properties for this device controller.

You should call this once per main loop. It is not called automatically.

Returns
0 on success.
-1 on error.

Definition at line 288 of file frameGrabber.hpp.

◆ updateINDI() [3/3]

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::updateINDI ( )
inherited

Update the INDI properties for this device controller.

You should call this once per main loop. It is not called automatically.

Returns
0 on success.
-1 on error.

Definition at line 1031 of file stdCamera.hpp.

◆ updatesIfChanged()

template<bool _useINDI>
template<typename T >
void MagAOX::app::MagAOXApp< _useINDI >::updatesIfChanged ( pcf::IndiProperty &  p,
const std::vector< const char * > &  els,
const std::vector< T > &  newVals,
pcf::IndiProperty::PropertyStateType  newState = pcf::IndiProperty::Ok 
)
protectedinherited
Parameters
p[in/out] The property containing the element to possibly update
[in]elsString vector of element names
[in]newValsthe new values
[in]newState[optional] The state of the property

Definition at line 3470 of file MagAOXApp.hpp.

◆ updateSwitchIfChanged()

template<bool _useINDI>
void MagAOX::app::MagAOXApp< _useINDI >::updateSwitchIfChanged ( pcf::IndiProperty &  p,
const std::string &  el,
const pcf::IndiElement::SwitchStateType &  newVal,
pcf::IndiProperty::PropertyStateType  ipState = pcf::IndiProperty::Ok 
)
protectedinherited

◆ whilePowerOff()

int MagAOX::app::ocam2KCtrl::whilePowerOff ( )
inlinevirtual

Implementation of the while-powered-off FSM.

Reimplemented from MagAOX::app::MagAOXApp< _useINDI >.

Definition at line 681 of file ocam2KCtrl.hpp.

References MagAOX::app::lock(), MagAOX::app::MagAOXApp< _useINDI >::log(), and MagAOX::app::MagAOXApp< _useINDI >::m_indiMutex.

Friends And Related Symbol Documentation

◆ dev::dssShutter< ocam2KCtrl >

Definition at line 1541 of file ocam2KCtrl.hpp.

◆ dev::edtCamera< ocam2KCtrl >

Definition at line 1541 of file ocam2KCtrl.hpp.

◆ dev::frameGrabber< ocam2KCtrl >

Definition at line 1541 of file ocam2KCtrl.hpp.

◆ dev::stdCamera< ocam2KCtrl >

Definition at line 1541 of file ocam2KCtrl.hpp.

◆ dev::telemeter< ocam2KCtrl >

Definition at line 1541 of file ocam2KCtrl.hpp.

Member Data Documentation

◆ c_edtCamera_relativeConfigPath

constexpr bool MagAOX::app::ocam2KCtrl::c_edtCamera_relativeConfigPath = true
staticconstexpr

app::dev config to tell edtCamera to use relative path to camera config file

Definition at line 89 of file ocam2KCtrl.hpp.

◆ c_frameGrabber_flippable

constexpr bool MagAOX::app::ocam2KCtrl::c_frameGrabber_flippable = false
staticconstexpr

app:dev config to tell framegrabber these images can not be flipped

Definition at line 91 of file ocam2KCtrl.hpp.

◆ c_stdCamera_cropMode

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_cropMode = false
staticconstexpr

app:dev config to tell stdCamera to expose Crop Mode controls

Definition at line 83 of file ocam2KCtrl.hpp.

◆ c_stdCamera_emGain

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_emGain = true
staticconstexpr

app::dev config to tell stdCamera to expose EM gain controls

Definition at line 69 of file ocam2KCtrl.hpp.

◆ c_stdCamera_exptimeCtrl

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_exptimeCtrl = false
staticconstexpr

app::dev config to tell stdCamera not to expose exposure time controls

Definition at line 71 of file ocam2KCtrl.hpp.

◆ c_stdCamera_fps

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_fps = true
staticconstexpr

app::dev config to tell stdCamera not to expose FPS status (ignored since fpsCtrl==true)

Definition at line 75 of file ocam2KCtrl.hpp.

◆ c_stdCamera_fpsCtrl

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_fpsCtrl = true
staticconstexpr

app::dev config to tell stdCamera to expose FPS controls

Definition at line 73 of file ocam2KCtrl.hpp.

◆ c_stdCamera_hasShutter

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_hasShutter = true
staticconstexpr

app:dev config to tell stdCamera to expose shutter controls

Definition at line 85 of file ocam2KCtrl.hpp.

◆ c_stdCamera_readoutSpeed

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_readoutSpeed = false
staticconstexpr

app::dev config to tell stdCamera not to expose readout speed controls

Definition at line 65 of file ocam2KCtrl.hpp.

◆ c_stdCamera_synchro

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_synchro = true
staticconstexpr

app::dev config to tell stdCamera to expose synchro mode controls

Definition at line 77 of file ocam2KCtrl.hpp.

◆ c_stdCamera_temp

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_temp = true
staticconstexpr

app::dev config to tell stdCamera to expose temperature (ignored since tempControl==true)

Definition at line 63 of file ocam2KCtrl.hpp.

◆ c_stdCamera_tempControl

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_tempControl = true
staticconstexpr

app::dev config to tell stdCamera to expose temperature controls

Definition at line 61 of file ocam2KCtrl.hpp.

◆ c_stdCamera_usesModes

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_usesModes = true
staticconstexpr

app:dev config to tell stdCamera not to expose mode controls

Definition at line 79 of file ocam2KCtrl.hpp.

◆ c_stdCamera_usesROI

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_usesROI = false
staticconstexpr

app:dev config to tell stdCamera to expose ROI controls

Definition at line 81 of file ocam2KCtrl.hpp.

◆ c_stdCamera_usesStateString

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_usesStateString = true
staticconstexpr

app::dev confg to tell stdCamera to expose the state string property

Definition at line 87 of file ocam2KCtrl.hpp.

◆ c_stdCamera_vShiftSpeed

constexpr bool MagAOX::app::ocam2KCtrl::c_stdCamera_vShiftSpeed = false
staticconstexpr

app:dev config to tell stdCamera not to expose vertical shift speed control

Definition at line 67 of file ocam2KCtrl.hpp.

◆ m_adcSpeed

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_adcSpeed
protectedinherited

Definition at line 349 of file stdCamera.hpp.

◆ m_allDefsReceived

template<bool _useINDI = true>
bool MagAOX::app::MagAOXApp< _useINDI >::m_allDefsReceived { false }
protectedinherited

Flag indicating that all registered Set properties have been updated since last Get.

Definition at line 681 of file MagAOXApp.hpp.

◆ m_atimes

mx::sigproc::circularBufferIndex<timespec, cbIndexT> MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_atimes
protectedinherited

Definition at line 147 of file frameGrabber.hpp.

◆ m_atimesD

std::vector<double> MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_atimesD
protectedinherited

Definition at line 150 of file frameGrabber.hpp.

◆ m_basePath

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_basePath
protectedinherited

The base path of the MagAO-X system.

Definition at line 170 of file MagAOXApp.hpp.

◆ m_calibDir

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_calibDir
protectedinherited

The path to calibration files for MagAOX.

Definition at line 178 of file MagAOXApp.hpp.

◆ m_cameraModes

cameraConfigMap MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_cameraModes
protectedinherited

Map holding the possible camera mode configurations.

Definition at line 297 of file stdCamera.hpp.

◆ m_cameraType

std::string MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_cameraType
protectedinherited

The camera type according to the framegrabber.

Definition at line 89 of file edtCamera.hpp.

◆ m_cbFPS

float MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_cbFPS
protectedinherited

The FPS used to configure the circular buffers.

Definition at line 145 of file frameGrabber.hpp.

◆ m_ccdTemp

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_ccdTemp
protectedinherited

The current temperature, in C.

Definition at line 316 of file stdCamera.hpp.

◆ m_ccdTempSetpt

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_ccdTempSetpt
protectedinherited

The desired temperature, in C.

Definition at line 318 of file stdCamera.hpp.

◆ m_channel

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_channel
protectedinherited

EDT PDV board channel number.

Definition at line 69 of file edtCamera.hpp.

◆ m_circBuffLength

uint32_t MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_circBuffLength
protectedinherited

Length of the circular buffer, in frames.

Definition at line 120 of file frameGrabber.hpp.

◆ m_configBase

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_configBase
protectedinherited

The name of a base config class for this app (minus .conf).

Definition at line 176 of file MagAOXApp.hpp.

◆ m_configDir

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_configDir
protectedinherited

The path to configuration files for MagAOX.

Definition at line 174 of file MagAOXApp.hpp.

Referenced by configureAcquisition().

◆ m_configName

◆ m_cpusetPath

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_cpusetPath { MAGAOX_cpusetPath }
protectedinherited

Path to the cpusets mount.

The path to the cpusets mount is configured by the environment variable defined by MAGOX_env_cpuset in environment.hpp. This environment variable is normally named "CGROUPS1_CPUSET_MOUNTPOINT". If the environment variable is not set, the default defined by MAGAOX_cpusetPath in paths.hpp is used.

Definition at line 189 of file MagAOXApp.hpp.

◆ m_cropMode

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_cropMode
protectedinherited

Status of crop mode ROIs, if enabled for this camera.

Definition at line 498 of file stdCamera.hpp.

◆ m_cropModeSet

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_cropModeSet
protectedinherited

Desired status of crop mode ROIs, if enabled for this camera.

Definition at line 499 of file stdCamera.hpp.

◆ m_currentROI

roi MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_currentROI
protectedinherited

Definition at line 426 of file stdCamera.hpp.

◆ m_currImageNumber

long MagAOX::app::ocam2KCtrl::m_currImageNumber {-1}
protected

The current image number, retrieved from the image itself.

Definition at line 110 of file ocam2KCtrl.hpp.

Referenced by acquireAndCheckValid().

◆ m_currImageTimestamp

timespec MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_currImageTimestamp
protectedinherited

The timestamp of the current image.

Definition at line 139 of file frameGrabber.hpp.

◆ m_dataType

uint8_t MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_dataType
protectedinherited

The ImageStreamIO type code.

Definition at line 133 of file frameGrabber.hpp.

◆ m_default_bin_x

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_default_bin_x
protectedinherited

Power-on ROI x binning.

Definition at line 458 of file stdCamera.hpp.

◆ m_default_bin_y

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_default_bin_y
protectedinherited

Power-on ROI y binning.

Definition at line 459 of file stdCamera.hpp.

◆ m_default_h

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_default_h
protectedinherited

Power-on ROI height.

Definition at line 457 of file stdCamera.hpp.

◆ m_default_w

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_default_w
protectedinherited

Power-on ROI width.

Definition at line 456 of file stdCamera.hpp.

◆ m_default_x

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_default_x
protectedinherited

Power-on ROI center x coordinate.

Definition at line 454 of file stdCamera.hpp.

◆ m_default_y

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_default_y
protectedinherited

Power-on ROI center y coordinate.

Definition at line 455 of file stdCamera.hpp.

◆ m_defaultFlip

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_defaultFlip
protectedinherited

Definition at line 126 of file frameGrabber.hpp.

◆ m_defaultReadoutSpeed

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_defaultReadoutSpeed
protectedinherited

The default readout speed of the camera.

Definition at line 303 of file stdCamera.hpp.

◆ m_defaultVShiftSpeed

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_defaultVShiftSpeed
protectedinherited

The default readout speed of the camera.

Definition at line 304 of file stdCamera.hpp.

◆ m_digitalBin

bool MagAOX::app::ocam2KCtrl::m_digitalBin {false}
protected

Definition at line 128 of file ocam2KCtrl.hpp.

Referenced by configureAcquisition(), and loadImageIntoStream().

◆ m_digitalBinWork

mx::improc::eigenImage<int16_t> MagAOX::app::ocam2KCtrl::m_digitalBinWork
protected

Definition at line 130 of file ocam2KCtrl.hpp.

Referenced by configureAcquisition(), and loadImageIntoStream().

◆ m_digitalBinX

unsigned MagAOX::app::ocam2KCtrl::m_digitalBinX {1}
protected

Definition at line 124 of file ocam2KCtrl.hpp.

Referenced by configureAcquisition(), and loadImageIntoStream().

◆ m_digitalBinY

unsigned MagAOX::app::ocam2KCtrl::m_digitalBinY {1}
protected

Definition at line 126 of file ocam2KCtrl.hpp.

Referenced by configureAcquisition().

◆ m_dioDevice

std::string MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_dioDevice
protectedinherited

The device controlling this shutter's digital I/O.

Definition at line 47 of file dssShutter.hpp.

◆ m_doOpen

bool MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_doOpen
protectedinherited

Flag telling the open thread that it should actually open the shutter, not just go back to sleep.

Definition at line 186 of file dssShutter.hpp.

◆ m_doShut

bool MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_doShut
protectedinherited

Flag telling the shut thread that it should actually shut the shutter, not just go back to sleep.

Definition at line 204 of file dssShutter.hpp.

◆ m_driverCtrlName

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_driverCtrlName
protectedinherited

Full path name of the INDI driver control FIFO.

This is currently only used to signal restarts.

Definition at line 692 of file MagAOXApp.hpp.

◆ m_driverInName

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_driverInName
protectedinherited

Full path name of the INDI driver input FIFO.

Definition at line 684 of file MagAOXApp.hpp.

◆ m_driverOutName

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_driverOutName
protectedinherited

Full path name of the INDI driver output FIFO.

Definition at line 687 of file MagAOXApp.hpp.

◆ m_dummy_c

char MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_dummy_c
protectedinherited

Definition at line 156 of file frameGrabber.hpp.

◆ m_dummy_cnt

uint64_t MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_dummy_cnt
protectedinherited

Definition at line 155 of file frameGrabber.hpp.

◆ m_dummy_ts

timespec MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_dummy_ts
protectedinherited

Definition at line 154 of file frameGrabber.hpp.

◆ m_emGain

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_emGain
protectedinherited

The camera's current EM gain (if available).

Definition at line 352 of file stdCamera.hpp.

◆ m_emGainSet

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_emGainSet
protectedinherited

The camera's EM gain, as set by the user.

Definition at line 353 of file stdCamera.hpp.

◆ m_euidCalled

template<bool _useINDI = true>
uid_t MagAOX::app::MagAOXApp< _useINDI >::m_euidCalled
privateinherited

The user id of the process as called (i.e. the higher privileged id of the owner, root if setuid).

Definition at line 404 of file MagAOXApp.hpp.

◆ m_euidReal

template<bool _useINDI = true>
uid_t MagAOX::app::MagAOXApp< _useINDI >::m_euidReal
privateinherited

The real user id of the proces (i.e. the lower privileged id of the user)

Definition at line 403 of file MagAOXApp.hpp.

◆ m_expTime

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_expTime
protectedinherited

The current exposure time, in seconds.

Definition at line 370 of file stdCamera.hpp.

◆ m_expTimeSet

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_expTimeSet
protectedinherited

The exposure time, in seconds, as set by user.

Definition at line 371 of file stdCamera.hpp.

◆ m_fgCpuset

std::string MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_fgCpuset
protectedinherited

The cpuset to assign the framegrabber thread to. Not used if empty, the default.

Definition at line 118 of file frameGrabber.hpp.

◆ m_fgThread

std::thread MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_fgThread
protectedinherited

A separate thread for the actual framegrabbings.

Definition at line 255 of file frameGrabber.hpp.

◆ m_fgThreadID

pid_t MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_fgThreadID
protectedinherited

The ID of the framegrabber thread.

Definition at line 251 of file frameGrabber.hpp.

◆ m_fgThreadInit

bool MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_fgThreadInit
protectedinherited

Synchronizer for thread startup, to allow priority setting to finish.

Definition at line 249 of file frameGrabber.hpp.

◆ m_fgThreadPrio

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_fgThreadPrio
protectedinherited

Priority of the framegrabber thread, should normally be > 00.

Definition at line 117 of file frameGrabber.hpp.

◆ m_fgThreadProp

pcf::IndiProperty MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_fgThreadProp
protectedinherited

The property to hold the f.g. thread details.

Definition at line 253 of file frameGrabber.hpp.

◆ m_fps

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_fps
protectedinherited

The current FPS.

Definition at line 377 of file stdCamera.hpp.

◆ m_fpsSet

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_fpsSet
protectedinherited

The commanded fps, as set by user.

Definition at line 378 of file stdCamera.hpp.

◆ m_full_bin_x

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_bin_x
protectedinherited

The x-binning in the full ROI.

Definition at line 465 of file stdCamera.hpp.

◆ m_full_bin_y

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_bin_y
protectedinherited

The y-binning in the full ROI.

Definition at line 466 of file stdCamera.hpp.

◆ m_full_currbin_h

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_currbin_h
protectedinherited

The current-binning full ROI height.

Definition at line 471 of file stdCamera.hpp.

◆ m_full_currbin_w

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_currbin_w
protectedinherited

The current-binning full ROI width.

Definition at line 470 of file stdCamera.hpp.

◆ m_full_currbin_x

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_currbin_x
protectedinherited

The current-binning full ROI center x coordinate.

Definition at line 468 of file stdCamera.hpp.

◆ m_full_currbin_y

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_currbin_y
protectedinherited

The current-binning full ROI center y coordinate.

Definition at line 469 of file stdCamera.hpp.

◆ m_full_h

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_h
protectedinherited

The full ROI height.

Definition at line 464 of file stdCamera.hpp.

◆ m_full_w

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_w
protectedinherited

The full ROI width.

Definition at line 463 of file stdCamera.hpp.

◆ m_full_x

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_x
protectedinherited

The full ROI center x coordinate.

Definition at line 461 of file stdCamera.hpp.

◆ m_full_y

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_full_y
protectedinherited

The full ROI center y coordinate.

Definition at line 462 of file stdCamera.hpp.

◆ m_gitAlert

template<bool _useINDI = true>
bool MagAOX::app::MagAOXApp< _useINDI >::m_gitAlert { false }
privateinherited

Definition at line 564 of file MagAOXApp.hpp.

◆ m_height

uint32_t MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_height
protectedinherited

The height of the image, once deinterlaced etc.

Definition at line 131 of file frameGrabber.hpp.

◆ m_image_p

u_char* MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_image_p
protectedinherited

The image data grabbed.

Definition at line 80 of file edtCamera.hpp.

◆ m_imageStream

IMAGE* MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_imageStream
protectedinherited

The ImageStreamIO shared memory buffer.

Definition at line 143 of file frameGrabber.hpp.

◆ m_indiDriver

template<bool _useINDI = true>
indiDriver<MagAOXApp>* MagAOX::app::MagAOXApp< _useINDI >::m_indiDriver { nullptr }
inherited

The INDI driver wrapper. Constructed and initialized by execute, which starts and stops communications.

Todo:
instead of making this public, provide an accessor.

Definition at line 641 of file MagAOXApp.hpp.

Referenced by MagAOX::app::picoMotorCtrl::appLogic(), MagAOX::app::smc100ccCtrl::appLogic(), MagAOX::app::zaberCtrl::appLogic(), MagAOX::app::streamWriter::updateINDI(), and MagAOX::app::magAOXMaths::updateVals().

◆ m_indiMutex

template<bool _useINDI = true>
std::mutex MagAOX::app::MagAOXApp< _useINDI >::m_indiMutex
inherited

Mutex for locking INDI communications.

Definition at line 644 of file MagAOXApp.hpp.

Referenced by MagAOX::app::acronameUsbHub::appLogic(), MagAOX::app::andorCtrl::appLogic(), MagAOX::app::baslerCtrl::appLogic(), MagAOX::app::cameraSim::appLogic(), MagAOX::app::filterWheelCtrl::appLogic(), MagAOX::app::hsfwCtrl::appLogic(), appLogic(), MagAOX::app::picamCtrl::appLogic(), MagAOX::app::picoMotorCtrl::appLogic(), MagAOX::app::siglentSDG::appLogic(), MagAOX::app::smc100ccCtrl::appLogic(), MagAOX::app::trippLitePDU::appLogic(), MagAOX::app::ttmModulator::appLogic(), MagAOX::app::xt1121Ctrl::appLogic(), MagAOX::app::xt1121DCDU::appLogic(), MagAOX::app::zaberCtrl::appLogic(), MagAOX::app::zylaCtrl::appLogic(), MagAOX::app::siglentSDG::changeAmp(), MagAOX::app::siglentSDG::changeFreq(), MagAOX::app::siglentSDG::changeOfst(), MagAOX::app::siglentSDG::changeOutp(), MagAOX::app::siglentSDG::changePhse(), MagAOX::app::siglentSDG::changeSync(), MagAOX::app::siglentSDG::changeWdth(), MagAOX::app::siglentSDG::changeWvtp(), MagAOX::app::xt1121Ctrl::channelSetCallback(), MagAOX::app::andorCtrl::configureAcquisition(), configureAcquisition(), MagAOX::app::picamCtrl::configureAcquisition(), MagAOX::app::qhyCtrl::configureAcquisition(), MagAOX::app::zylaCtrl::configureAcquisition(), MagAOX::app::INDI_NEWCALLBACK_DEFN(), MagAOX::app::picoMotorCtrl::newCallBack_picopos(), MagAOX::app::picoMotorCtrl::newCallBack_presetName(), MagAOX::app::acronameUsbHub::onPowerOff(), MagAOX::app::andorCtrl::onPowerOff(), onPowerOff(), MagAOX::app::picamCtrl::onPowerOff(), MagAOX::app::siglentSDG::onPowerOff(), MagAOX::app::xt1121Ctrl::onPowerOff(), MagAOX::app::zylaCtrl::onPowerOff(), MagAOX::app::filterWheelCtrl::onPowerOnConnect(), reconfig(), MagAOX::app::zylaCtrl::reconfig(), MagAOX::app::filterWheelCtrl::stop(), MagAOX::app::trippLitePDU::turnOutletOff(), MagAOX::app::xt1121DCDU::turnOutletOff(), MagAOX::app::trippLitePDU::turnOutletOn(), MagAOX::app::xt1121DCDU::turnOutletOn(), whilePowerOff(), and MagAOX::app::zylaCtrl::whilePowerOff().

◆ m_indiNewCallBacks

template<bool _useINDI = true>
std::unordered_map<std::string, indiCallBack> MagAOX::app::MagAOXApp< _useINDI >::m_indiNewCallBacks
protectedinherited

Map to hold the NewProperty indiCallBacks for this App, with fast lookup by property name.

The key for these is the property name.

Definition at line 672 of file MagAOXApp.hpp.

◆ m_indiP_clearFSMAlert

template<bool _useINDI = true>
pcf::IndiProperty MagAOX::app::MagAOXApp< _useINDI >::m_indiP_clearFSMAlert
protectedinherited

indi Property to clear an FSM alert.

Definition at line 1087 of file MagAOXApp.hpp.

◆ m_indiP_cropMode

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_cropMode
protectedinherited

Property used to toggle crop mode on and off.

Definition at line 501 of file stdCamera.hpp.

◆ m_indiP_emGain

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_emGain
protectedinherited

Definition at line 359 of file stdCamera.hpp.

◆ m_indiP_emProt

pcf::IndiProperty MagAOX::app::ocam2KCtrl::m_indiP_emProt
protected

◆ m_indiP_emProtReset

pcf::IndiProperty MagAOX::app::ocam2KCtrl::m_indiP_emProtReset
protected

Definition at line 321 of file ocam2KCtrl.hpp.

Referenced by appStartup(), and MagAOX::app::INDI_NEWCALLBACK_DEFN().

◆ m_indiP_exptime

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_exptime
protectedinherited

Definition at line 380 of file stdCamera.hpp.

◆ m_indiP_fps

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_fps
protectedinherited

Definition at line 382 of file stdCamera.hpp.

◆ m_indiP_frameSize

pcf::IndiProperty MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_indiP_frameSize
protectedinherited

Property used to report the current frame size.

Definition at line 276 of file frameGrabber.hpp.

◆ m_indiP_fullROI

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_fullROI
protectedinherited

Property used to preset the full ROI dimensions.

Definition at line 480 of file stdCamera.hpp.

◆ m_indiP_mode

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_mode
protectedinherited

Property used to report the current mode.

Definition at line 405 of file stdCamera.hpp.

◆ m_indiP_powerChannel [1/2]

pcf::IndiProperty MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_indiP_powerChannel
protectedinherited

Property used to monitor the shutter's power state.

Definition at line 231 of file dssShutter.hpp.

◆ m_indiP_powerChannel [2/2]

template<bool _useINDI = true>
pcf::IndiProperty MagAOX::app::MagAOXApp< _useINDI >::m_indiP_powerChannel
protectedinherited

INDI property used to communicate power state.

Definition at line 1143 of file MagAOXApp.hpp.

◆ m_indiP_readoutSpeed

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_readoutSpeed
protectedinherited

Definition at line 356 of file stdCamera.hpp.

◆ m_indiP_reconfig

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_reconfig
protectedinherited

Request switch which forces the framegrabber to go through the reconfigure process.

Definition at line 408 of file stdCamera.hpp.

◆ m_indiP_roi_bin_x

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_bin_x
protectedinherited

Property used to set the ROI x binning.

Definition at line 477 of file stdCamera.hpp.

◆ m_indiP_roi_bin_y

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_bin_y
protectedinherited

Property used to set the ROI y binning.

Definition at line 478 of file stdCamera.hpp.

◆ m_indiP_roi_check

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_check
protectedinherited

Property used to trigger checking the target ROI.

Definition at line 482 of file stdCamera.hpp.

◆ m_indiP_roi_default

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_default
protectedinherited

Property used to trigger setting the default and startup ROI.

Definition at line 490 of file stdCamera.hpp.

◆ m_indiP_roi_full

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_full
protectedinherited

Property used to trigger setting the full ROI.

Definition at line 486 of file stdCamera.hpp.

◆ m_indiP_roi_fullbin

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_fullbin
protectedinherited

Property used to trigger setting the full in current binning ROI.

Definition at line 487 of file stdCamera.hpp.

◆ m_indiP_roi_h

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_h
protectedinherited

Property used to set the ROI height.

Definition at line 476 of file stdCamera.hpp.

◆ m_indiP_roi_last

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_last
protectedinherited

Property used to trigger setting the last ROI.

Definition at line 489 of file stdCamera.hpp.

◆ m_indiP_roi_loadlast

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_loadlast
protectedinherited

Property used to trigger loading the last ROI as the target.

Definition at line 488 of file stdCamera.hpp.

◆ m_indiP_roi_set

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_set
protectedinherited

Property used to trigger setting the ROI.

Definition at line 484 of file stdCamera.hpp.

◆ m_indiP_roi_w

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_w
protectedinherited

Property used to set the ROI width.

Definition at line 475 of file stdCamera.hpp.

◆ m_indiP_roi_x

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_x
protectedinherited

Property used to set the ROI x center coordinate.

Definition at line 473 of file stdCamera.hpp.

◆ m_indiP_roi_y

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_roi_y
protectedinherited

Property used to set the ROI x center coordinate.

Definition at line 474 of file stdCamera.hpp.

◆ m_indiP_sensorChannel

pcf::IndiProperty MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_indiP_sensorChannel
protectedinherited

Property used to monitor the shutter's hall sensor.

Definition at line 232 of file dssShutter.hpp.

◆ m_indiP_shmimName

pcf::IndiProperty MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_indiP_shmimName
protectedinherited

Property used to report the shmim buffer name.

Definition at line 274 of file frameGrabber.hpp.

◆ m_indiP_shutter

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_shutter
protectedinherited

Property used to control the shutter, a switch.

Definition at line 512 of file stdCamera.hpp.

◆ m_indiP_shutterStatus

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_shutterStatus
protectedinherited

State of the shutter. 0 = shut, 1 = open, -1 = unknown.

Property to report shutter status

Definition at line 511 of file stdCamera.hpp.

◆ m_indiP_state

template<bool _useINDI = true>
pcf::IndiProperty MagAOX::app::MagAOXApp< _useINDI >::m_indiP_state
protectedinherited

indi Property to report the application state.

Definition at line 1084 of file MagAOXApp.hpp.

◆ m_indiP_stateString

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_stateString
protectedinherited

Definition at line 520 of file stdCamera.hpp.

◆ m_indiP_syncFreq

pcf::IndiProperty MagAOX::app::ocam2KCtrl::m_indiP_syncFreq
protected

Definition at line 323 of file ocam2KCtrl.hpp.

Referenced by appStartup(), and MagAOX::app::INDI_SETCALLBACK_DEFN().

◆ m_indiP_synchro

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_synchro
protectedinherited

Definition at line 393 of file stdCamera.hpp.

◆ m_indiP_temp

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_temp
protectedinherited

Definition at line 327 of file stdCamera.hpp.

◆ m_indiP_tempcont

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_tempcont
protectedinherited

Definition at line 328 of file stdCamera.hpp.

◆ m_indiP_temps

pcf::IndiProperty MagAOX::app::ocam2KCtrl::m_indiP_temps
protected

Definition at line 319 of file ocam2KCtrl.hpp.

Referenced by appStartup(), getTemps(), and onPowerOff().

◆ m_indiP_tempstat

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_tempstat
protectedinherited

Definition at line 329 of file stdCamera.hpp.

◆ m_indiP_timing

pcf::IndiProperty MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_indiP_timing
protectedinherited

Definition at line 278 of file frameGrabber.hpp.

◆ m_indiP_triggerChannel

pcf::IndiProperty MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_indiP_triggerChannel
protectedinherited

Property used to monitor and set the shutter's trigger.

Definition at line 233 of file dssShutter.hpp.

◆ m_indiP_vShiftSpeed

pcf::IndiProperty MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_indiP_vShiftSpeed
protectedinherited

Definition at line 357 of file stdCamera.hpp.

◆ m_indiSetCallBacks

template<bool _useINDI = true>
std::unordered_map<std::string, indiCallBack> MagAOX::app::MagAOXApp< _useINDI >::m_indiSetCallBacks
protectedinherited

Map to hold the SetProperty indiCallBacks for this App, with fast lookup by property name.

The key for these is device.name

Definition at line 677 of file MagAOXApp.hpp.

◆ m_lastImageNumber

long MagAOX::app::ocam2KCtrl::m_lastImageNumber {-1}
protected

The last image number, saved from the last loop through.

Definition at line 112 of file ocam2KCtrl.hpp.

Referenced by acquireAndCheckValid(), and startAcquisition().

◆ m_lastROI

roi MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_lastROI
protectedinherited

Definition at line 428 of file stdCamera.hpp.

◆ m_latencyCircBuffMaxLength

cbIndexT MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_latencyCircBuffMaxLength
protectedinherited

Maximum length of the latency measurement circular buffers.

Definition at line 122 of file frameGrabber.hpp.

◆ m_latencyCircBuffMaxTime

float MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_latencyCircBuffMaxTime
protectedinherited

Maximum time of the latency meaurement circular buffers.

Definition at line 124 of file frameGrabber.hpp.

◆ m_log

template<bool _useINDI>
MagAOXApp< _useINDI >::logManagerT MagAOX::app::MagAOXApp< _useINDI >::m_log
staticinherited

Definition at line 327 of file MagAOXApp.hpp.

◆ m_loopPause

template<bool _useINDI = true>
unsigned long MagAOX::app::MagAOXApp< _useINDI >::m_loopPause { MAGAOX_default_loopPause }
protectedinherited

The time in nanoseconds to pause the main loop. The appLogic() function of the derived class is called every m_loopPause nanoseconds. Default is 1,000,000,000 ns. Config with loopPause=X.

Definition at line 191 of file MagAOXApp.hpp.

Referenced by MagAOX::app::trippLitePDU::trippLitePDU(), and MagAOX::app::siglentSDG::appLogic().

◆ m_maxa

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_maxa
protectedinherited

Definition at line 161 of file frameGrabber.hpp.

◆ m_maxEMGain

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxEMGain
protectedinherited

The configurable maximum EM gain. To be enforced in derivedT.

Definition at line 354 of file stdCamera.hpp.

◆ m_maxExpTime

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxExpTime
protectedinherited

The maximum exposure time, used for INDI attributes.

Definition at line 367 of file stdCamera.hpp.

◆ m_maxFPS

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxFPS
protectedinherited

The maximum FPS, used for INDI attributes.

Definition at line 374 of file stdCamera.hpp.

◆ m_maxInterval

double MagAOX::app::dev::telemeter< ocam2KCtrl >::m_maxInterval
inherited

The maximum interval, in seconds, between telemetry records. Default is 10.0 seconds.

Definition at line 83 of file telemeter.hpp.

◆ m_maxROIBinning_x

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxROIBinning_x
protectedinherited

Definition at line 447 of file stdCamera.hpp.

◆ m_maxROIBinning_y

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxROIBinning_y
protectedinherited

Definition at line 451 of file stdCamera.hpp.

◆ m_maxROIHeight

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxROIHeight
protectedinherited

Definition at line 443 of file stdCamera.hpp.

◆ m_maxROIWidth

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxROIWidth
protectedinherited

Definition at line 439 of file stdCamera.hpp.

◆ m_maxROIx

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxROIx
protectedinherited

Definition at line 431 of file stdCamera.hpp.

◆ m_maxROIy

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxROIy
protectedinherited

Definition at line 435 of file stdCamera.hpp.

◆ m_maxTemp

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_maxTemp
protectedinherited

Definition at line 313 of file stdCamera.hpp.

◆ m_maxw

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_maxw
protectedinherited

Definition at line 166 of file frameGrabber.hpp.

◆ m_mina

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_mina
protectedinherited

Definition at line 160 of file frameGrabber.hpp.

◆ m_minExpTime

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minExpTime
protectedinherited

The minimum exposure time, used for INDI attributes.

Definition at line 366 of file stdCamera.hpp.

◆ m_minFPS

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minFPS
protectedinherited

The minimum FPS, used for INDI attributes.

Definition at line 373 of file stdCamera.hpp.

◆ m_minROIBinning_x

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minROIBinning_x
protectedinherited

Definition at line 446 of file stdCamera.hpp.

◆ m_minROIBinning_y

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minROIBinning_y
protectedinherited

Definition at line 450 of file stdCamera.hpp.

◆ m_minROIHeight

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minROIHeight
protectedinherited

Definition at line 442 of file stdCamera.hpp.

◆ m_minROIWidth

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minROIWidth
protectedinherited

Definition at line 438 of file stdCamera.hpp.

◆ m_minROIx

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minROIx
protectedinherited

Definition at line 430 of file stdCamera.hpp.

◆ m_minROIy

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minROIy
protectedinherited

Definition at line 434 of file stdCamera.hpp.

◆ m_minTemp

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_minTemp
protectedinherited

Definition at line 312 of file stdCamera.hpp.

◆ m_minw

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_minw
protectedinherited

Definition at line 165 of file frameGrabber.hpp.

◆ m_mna

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_mna
protectedinherited

Definition at line 158 of file frameGrabber.hpp.

◆ m_mnw

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_mnw
protectedinherited

Definition at line 163 of file frameGrabber.hpp.

◆ m_mnwa

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_mnwa
protectedinherited

Definition at line 168 of file frameGrabber.hpp.

◆ m_modeName

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_modeName
protectedinherited

The current mode name.

Definition at line 401 of file stdCamera.hpp.

◆ m_nextMode

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_nextMode
protectedinherited

The mode to be set by the next reconfiguration.

Definition at line 403 of file stdCamera.hpp.

◆ m_nextROI

roi MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_nextROI
protectedinherited

Definition at line 427 of file stdCamera.hpp.

◆ m_numBuffs

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_numBuffs
protectedinherited

EDT PDV DMA buffer size, indicating number of images.

Definition at line 70 of file edtCamera.hpp.

◆ m_ocam2_id

ocam2_id MagAOX::app::ocam2KCtrl::m_ocam2_id {0}
protected

OCAM SDK id.

Definition at line 108 of file ocam2KCtrl.hpp.

Referenced by configureAcquisition(), and loadImageIntoStream().

◆ m_ocamDescrambleFile

std::string MagAOX::app::ocam2KCtrl::m_ocamDescrambleFile
protected

Path the OCAM 2K pixel descrambling file, relative to MagAO-X config directory.

Definition at line 102 of file ocam2KCtrl.hpp.

Referenced by configureAcquisition(), and loadConfig().

◆ m_openThread

std::thread MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_openThread
protectedinherited

The opening thread.

Definition at line 194 of file dssShutter.hpp.

◆ m_openThreadID

pid_t MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_openThreadID
protectedinherited

Open thread PID.

Definition at line 190 of file dssShutter.hpp.

◆ m_openThreadInit

bool MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_openThreadInit
protectedinherited

Initialization flag for the open thread.

Definition at line 188 of file dssShutter.hpp.

◆ m_openThreadProp

pcf::IndiProperty MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_openThreadProp
protectedinherited

The property to hold the open thread details.

Definition at line 192 of file dssShutter.hpp.

◆ m_pdv

PdvDev* MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_pdv
protectedinherited

The EDT PDV device handle.

Definition at line 78 of file edtCamera.hpp.

◆ m_pid

template<bool _useINDI = true>
pid_t MagAOX::app::MagAOXApp< _useINDI >::m_pid { 0 }
protectedinherited

This process's PID.

Definition at line 488 of file MagAOXApp.hpp.

◆ m_powerChannel [1/2]

std::string MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_powerChannel
protectedinherited

The channel controlling this shutter's power.

Definition at line 45 of file dssShutter.hpp.

◆ m_powerChannel [2/2]

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_powerChannel
protectedinherited

The INDI property name of the channel controlling this device's power.

Definition at line 1129 of file MagAOXApp.hpp.

◆ m_powerDevice [1/2]

std::string MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_powerDevice
protectedinherited

The device controlling this shutter's power.

Definition at line 44 of file dssShutter.hpp.

◆ m_powerDevice [2/2]

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_powerDevice
protectedinherited

The INDI device name of the power controller.

Definition at line 1128 of file MagAOXApp.hpp.

◆ m_poweredOn

bool MagAOX::app::ocam2KCtrl::m_poweredOn {false}
protected

Definition at line 120 of file ocam2KCtrl.hpp.

Referenced by appLogic(), and onPowerOff().

◆ m_powerElement

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_powerElement { "state" }
protectedinherited

The INDI element name to monitor for this device's power state.

Definition at line 1130 of file MagAOXApp.hpp.

◆ m_powerMgtEnabled

◆ m_powerOnCounter

template<bool _useINDI = true>
int MagAOX::app::MagAOXApp< _useINDI >::m_powerOnCounter { -1 }
protectedinherited

Counts numer of loops after power on, implements delay for device bootup. If -1, then device was NOT powered off on app startup.

Definition at line 1136 of file MagAOXApp.hpp.

Referenced by MagAOX::app::andorCtrl::onPowerOff(), onPowerOff(), and MagAOX::app::zylaCtrl::onPowerOff().

◆ m_powerOnWait

template<bool _useINDI = true>
unsigned long MagAOX::app::MagAOXApp< _useINDI >::m_powerOnWait { 0 }
protectedinherited

◆ m_powerState [1/2]

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_powerState
protectedinherited

The current power state, -1 is unknown, 0 is off, 1 is on.

Definition at line 56 of file dssShutter.hpp.

◆ m_powerState [2/2]

◆ m_powerTargetElement

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_powerTargetElement { "target" }
protectedinherited

The INDI element name to monitor for this device's power state.

Definition at line 1131 of file MagAOXApp.hpp.

◆ m_powerTargetState

◆ m_protectionReset

bool MagAOX::app::ocam2KCtrl::m_protectionReset {false}
protected

Flag indicating that protection has been reset at least once.

Definition at line 114 of file ocam2KCtrl.hpp.

Referenced by resetEMProtection(), and setEMGain().

◆ m_protectionResetConfirmed

unsigned MagAOX::app::ocam2KCtrl::m_protectionResetConfirmed {0}
protected

Counter indicating the number of times that the protection reset has been requested within 10 seconds, for confirmation.

Definition at line 116 of file ocam2KCtrl.hpp.

Referenced by appLogic(), MagAOX::app::INDI_NEWCALLBACK_DEFN(), and resetEMProtection().

◆ m_protectionResetReqTime

double MagAOX::app::ocam2KCtrl::m_protectionResetReqTime {0}
protected

The time at which protection reset was requested. You have 10 seconds to confirm.

Definition at line 118 of file ocam2KCtrl.hpp.

Referenced by appLogic(), and MagAOX::app::INDI_NEWCALLBACK_DEFN().

◆ m_raw_depth

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_raw_depth
protectedinherited

The bit-depth of the frame, according to the framegrabber.

Definition at line 88 of file edtCamera.hpp.

◆ m_raw_height

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_raw_height
protectedinherited

The height of the frame, according to the framegrabber.

Definition at line 86 of file edtCamera.hpp.

◆ m_raw_width

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_raw_width
protectedinherited

The width of the frame, according to the framegrabber.

Definition at line 87 of file edtCamera.hpp.

◆ m_readoutSpeedName

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_readoutSpeedName
protectedinherited

The current readout speed name.

Definition at line 340 of file stdCamera.hpp.

◆ m_readoutSpeedNameLabels

std::vector<std::string> MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_readoutSpeedNameLabels
protectedinherited

Definition at line 338 of file stdCamera.hpp.

◆ m_readoutSpeedNames

std::vector<std::string> MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_readoutSpeedNames
protectedinherited

Definition at line 337 of file stdCamera.hpp.

◆ m_readoutSpeedNameSet

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_readoutSpeedNameSet
protectedinherited

The user requested readout speed name, to be set by derived()

Definition at line 341 of file stdCamera.hpp.

◆ m_readTimeout

◆ m_reconfig

bool MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_reconfig
protectedinherited

Flag to set if a camera reconfiguration requires a framegrabber reset.

Definition at line 141 of file frameGrabber.hpp.

◆ m_secretsPath

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_secretsPath
protectedinherited

Path to the secrets directory, where passwords, etc, are stored.

Definition at line 182 of file MagAOXApp.hpp.

◆ m_self

template<bool _useINDI>
MagAOXApp< _useINDI > * MagAOX::app::MagAOXApp< _useINDI >::m_self = nullptr
staticprivateinherited

Static pointer to this (set in constructor). Used to test whether a a MagAOXApp is already instatiated (a fatal error) and used for getting out of static signal handlers.

Definition at line 379 of file MagAOXApp.hpp.

◆ m_sensorChannel

std::string MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_sensorChannel
protectedinherited

The channel reading this shutter's sensor.

Definition at line 48 of file dssShutter.hpp.

◆ m_sensorState

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_sensorState
protectedinherited

The current sensor state, -1 is unknown, 0 is shut, 1 is open.

Definition at line 58 of file dssShutter.hpp.

◆ m_shmimName

std::string MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_shmimName
protectedinherited

The name of the shared memory image, is used in /tmp/<shmimName>.im.shm. Derived classes should set a default.

Definition at line 114 of file frameGrabber.hpp.

◆ m_shutdown

◆ m_shutterState

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_shutterState
protectedinherited

Definition at line 509 of file stdCamera.hpp.

◆ m_shutterStatus

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_shutterStatus
protectedinherited

Definition at line 508 of file stdCamera.hpp.

◆ m_shutterTimeout

unsigned MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_shutterTimeout
protectedinherited

Total time to wait for sensor to change state before timing out [msec]. Default is 2000.

Definition at line 53 of file dssShutter.hpp.

◆ m_shutterWait

unsigned MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_shutterWait
protectedinherited

The time to pause between checks of the sensor state during open/shut [msec]. Default is 100.

Definition at line 51 of file dssShutter.hpp.

◆ m_shutThread

std::thread MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_shutThread
protectedinherited

The shutting thread.

Definition at line 212 of file dssShutter.hpp.

◆ m_shutThreadID

pid_t MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_shutThreadID
protectedinherited

Shut thread PID.

Definition at line 208 of file dssShutter.hpp.

◆ m_shutThreadInit

bool MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_shutThreadInit
protectedinherited

Initialization flag for the shut thread.

Definition at line 206 of file dssShutter.hpp.

◆ m_shutThreadProp

pcf::IndiProperty MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_shutThreadProp
protectedinherited

The property to hold the shut thread details.

Definition at line 210 of file dssShutter.hpp.

◆ m_startupMode

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_startupMode
protectedinherited

The camera mode to load during first init after a power-on.

Definition at line 299 of file stdCamera.hpp.

◆ m_startupTemp

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_startupTemp
protectedinherited

The temperature to set after a power-on. Set to <= -999 to not use [default].

Definition at line 301 of file stdCamera.hpp.

◆ m_state

template<bool _useINDI = true>
stateCodes::stateCodeT MagAOX::app::MagAOXApp< _useINDI >::m_state { stateCodes::UNINITIALIZED }
privateinherited

The application's state. Never ever set this directly, use state(const stateCodeT & s).

Definition at line 558 of file MagAOXApp.hpp.

◆ m_stateAlert

template<bool _useINDI = true>
bool MagAOX::app::MagAOXApp< _useINDI >::m_stateAlert { false }
privateinherited

Definition at line 561 of file MagAOXApp.hpp.

◆ m_stateLogged

template<bool _useINDI = true>
int MagAOX::app::MagAOXApp< _useINDI >::m_stateLogged { 0 }
privateinherited

Counter and flag for use to log errors just once. Never ever access directly, use stateLogged().

Definition at line 566 of file MagAOXApp.hpp.

◆ m_stepExpTime

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepExpTime
protectedinherited

The maximum exposure time stepsize, used for INDI attributes.

Definition at line 368 of file stdCamera.hpp.

◆ m_stepFPS

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepFPS
protectedinherited

The FPS step size, used for INDI attributes.

Definition at line 375 of file stdCamera.hpp.

◆ m_stepROIBinning_x

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepROIBinning_x
protectedinherited

Definition at line 448 of file stdCamera.hpp.

◆ m_stepROIBinning_y

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepROIBinning_y
protectedinherited

Definition at line 452 of file stdCamera.hpp.

◆ m_stepROIHeight

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepROIHeight
protectedinherited

Definition at line 444 of file stdCamera.hpp.

◆ m_stepROIWidth

int MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepROIWidth
protectedinherited

Definition at line 440 of file stdCamera.hpp.

◆ m_stepROIx

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepROIx
protectedinherited

Definition at line 432 of file stdCamera.hpp.

◆ m_stepROIy

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepROIy
protectedinherited

Definition at line 436 of file stdCamera.hpp.

◆ m_stepTemp

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_stepTemp
protectedinherited

Definition at line 314 of file stdCamera.hpp.

◆ m_suid

template<bool _useINDI = true>
uid_t MagAOX::app::MagAOXApp< _useINDI >::m_suid
privateinherited

The save-set user id of the process.

Definition at line 406 of file MagAOXApp.hpp.

◆ m_syncDevice

std::string MagAOX::app::ocam2KCtrl::m_syncDevice {"fxngensync"}
protected

Definition at line 132 of file ocam2KCtrl.hpp.

Referenced by appStartup(), and setFPS().

◆ m_syncFreq

float MagAOX::app::ocam2KCtrl::m_syncFreq {0}
protected

Definition at line 135 of file ocam2KCtrl.hpp.

Referenced by getFPS(), and MagAOX::app::INDI_SETCALLBACK_DEFN().

◆ m_syncFreqProp

std::string MagAOX::app::ocam2KCtrl::m_syncFreqProp {"C1freq"}
protected

Definition at line 133 of file ocam2KCtrl.hpp.

Referenced by appStartup(), and setFPS().

◆ m_synchro

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_synchro
protectedinherited

Status of synchronization, true is on, false is off.

Definition at line 391 of file stdCamera.hpp.

◆ m_synchroSet

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_synchroSet
protectedinherited

Target status of m_synchro.

Definition at line 389 of file stdCamera.hpp.

◆ m_sysPath

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::m_sysPath
protectedinherited

The path to the system directory, for PID file, etc.

Definition at line 180 of file MagAOXApp.hpp.

Referenced by MagAOX::app::picoMotorCtrl::readChannelCounts(), and MagAOX::app::picoMotorCtrl::writeChannelCounts().

◆ m_tel

Definition at line 81 of file telemeter.hpp.

◆ m_tempControlOnTarget

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_tempControlOnTarget
protectedinherited

Whether or not the temperature control system is on its target temperature.

Definition at line 323 of file stdCamera.hpp.

◆ m_tempControlStatus

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_tempControlStatus
protectedinherited

Whether or not temperature control is active.

Definition at line 320 of file stdCamera.hpp.

◆ m_tempControlStatusSet

bool MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_tempControlStatusSet
protectedinherited

Desired state of temperature control.

Definition at line 321 of file stdCamera.hpp.

◆ m_tempControlStatusStr

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_tempControlStatusStr
protectedinherited

Camera specific description of temperature control status.

Definition at line 325 of file stdCamera.hpp.

◆ m_temps

ocamTemps MagAOX::app::ocam2KCtrl::m_temps
protected

Structure holding the last temperature measurement.

Definition at line 122 of file ocam2KCtrl.hpp.

Referenced by appLogic(), appStartup(), getTemps(), and onPowerOff().

◆ m_triggerChannel

std::string MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_triggerChannel
protectedinherited

The channel sending this shutter's trigger.

Definition at line 49 of file dssShutter.hpp.

◆ m_triggerState

int MagAOX::app::dev::dssShutter< ocam2KCtrl >::m_triggerState
protectedinherited

The current trigger state. -1 is unknown, 0 is low, 1 is high.

Definition at line 60 of file dssShutter.hpp.

◆ m_typeSize

size_t MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_typeSize
protectedinherited

The size of the type, in bytes. Result of sizeof.

Definition at line 134 of file frameGrabber.hpp.

◆ m_unit

int MagAOX::app::dev::edtCamera< ocam2KCtrl >::m_unit
protectedinherited

EDT PDV board unit number.

Definition at line 68 of file edtCamera.hpp.

◆ m_useINDI

template<bool _useINDI = true>
constexpr bool MagAOX::app::MagAOXApp< _useINDI >::m_useINDI = _useINDI
staticconstexprprotectedinherited

Flag controlling whether INDI is used. If false, then no INDI code executes.

Definition at line 636 of file MagAOXApp.hpp.

◆ m_vara

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_vara
protectedinherited

Definition at line 159 of file frameGrabber.hpp.

◆ m_varw

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_varw
protectedinherited

Definition at line 164 of file frameGrabber.hpp.

◆ m_varwa

double MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_varwa
protectedinherited

Definition at line 169 of file frameGrabber.hpp.

◆ m_vshiftSpeed

float MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_vshiftSpeed
protectedinherited

Definition at line 350 of file stdCamera.hpp.

◆ m_vShiftSpeedName

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_vShiftSpeedName
protectedinherited

The current vshift speed name.

Definition at line 346 of file stdCamera.hpp.

◆ m_vShiftSpeedNameLabels

std::vector<std::string> MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_vShiftSpeedNameLabels
protectedinherited

Definition at line 344 of file stdCamera.hpp.

◆ m_vShiftSpeedNames

std::vector<std::string> MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_vShiftSpeedNames
protectedinherited

Definition at line 343 of file stdCamera.hpp.

◆ m_vShiftSpeedNameSet

std::string MagAOX::app::dev::stdCamera< ocam2KCtrl >::m_vShiftSpeedNameSet
protectedinherited

The user requested vshift speed name, to be set by derived()

Definition at line 347 of file stdCamera.hpp.

◆ m_watimesD

std::vector<double> MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_watimesD
protectedinherited

Definition at line 152 of file frameGrabber.hpp.

◆ m_width

uint32_t MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_width
protectedinherited

The width of the image, once deinterlaced etc.

Definition at line 130 of file frameGrabber.hpp.

◆ m_writeTimeout

◆ m_wtimes

mx::sigproc::circularBufferIndex<timespec, cbIndexT> MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_wtimes
protectedinherited

Definition at line 148 of file frameGrabber.hpp.

◆ m_wtimesD

std::vector<double> MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_wtimesD
protectedinherited

Definition at line 151 of file frameGrabber.hpp.

◆ m_xbinning

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_xbinning
protectedinherited

The x-binning according to the framegrabber.

Definition at line 136 of file frameGrabber.hpp.

◆ m_ybinning

int MagAOX::app::dev::frameGrabber< ocam2KCtrl >::m_ybinning
protectedinherited

The y-binning according to the framegrabber.

Definition at line 137 of file frameGrabber.hpp.

◆ pidFileName

template<bool _useINDI = true>
std::string MagAOX::app::MagAOXApp< _useINDI >::pidFileName
protectedinherited

The name of the PID file.

Definition at line 486 of file MagAOXApp.hpp.


The documentation for this class was generated from the following file: