The MagAO-X pvcam controller. More...
#include <pvcamCtrl.hpp>


| Classes | |
| struct | gain | 
| struct | port | 
| struct | speed | 
| 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< pvcamCtrl, logFileRaw< verboseT > > | logManagerT | 
| The log manager type. | |
| Public Member Functions | |
| pvcamCtrl () | |
| Default c'tor. | |
| ~pvcamCtrl () noexcept | |
| D'tor, declared and defined for noexcept. | |
| virtual void | setupConfig () | 
| int | loadConfigImpl (mx::app::appConfigurator &_config) | 
| Implementation of loadConfig logic, separated for testing. | |
| virtual void | loadConfig () | 
| virtual int | appStartup () | 
| Startup function. | |
| virtual int | appLogic () | 
| Implementation of the FSM for pvcamCtrl. | |
| virtual int | appShutdown () | 
| Shutdown the app. | |
| int | powerOnDefaults () | 
| int | setTempControl () | 
| int | setTempSetPt () | 
| int | setReadoutSpeed () | 
| int | setVShiftSpeed () | 
| int | setEMGain () | 
| int | setExpTime () | 
| int | setFPS () | 
| int | checkNextROI () | 
| Check the next ROI. | |
| int | setNextROI () | 
| int | setShutter (int sh) | 
| Sets the shutter state, via call to dssShutter::setShutterState(int) [stdCamera interface]. | |
| int | configureAcquisition () | 
| float | fps () | 
| int | startAcquisition () | 
| int | acquireAndCheckValid () | 
| int | loadImageIntoStream (void *dest) | 
| int | reconfig () | 
| int | connect () | 
| int | fillSpeedTable () | 
| void | dumpEnum (uns32 paramID, const std::string ¶mMnem) | 
| int | getTemp () | 
| void | endOfFrameCallback (FRAME_INFO *finfo) | 
| 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 | onPowerOff () | 
| Actions on power off. | |
| int | whilePowerOff () | 
| Actions while powered off. | |
| int | setupConfig (mx::app::appConfigurator &config) | 
| Setup the configuration system. | |
| int | loadConfig (mx::app::appConfigurator &config) | 
| load the configuration system results | |
| int | onPowerOff () | 
| On power off, sets m_reconfig to true. | |
| int | configCircBuffs () | 
| void | setupConfig (mx::app::appConfigurator &config) | 
| Setup the configuration system. | |
| void | loadConfig (mx::app::appConfigurator &config) | 
| load the configuration system results | |
| int | onPowerOff () | 
| Actions on power off. | |
| int | whilePowerOff () | 
| Actions while powered off. | |
| 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. | |
| Telemeter Interface | |
| int | checkRecordTimes () | 
| int | recordTelem (const telem_stdcam *) | 
| int | recordTelem (const telem_fgtimings *) | 
| Threads | |
| 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) | 
| Telemeter Interface | |
| int | recordFGTimings (bool force=false) | 
| Static Public Member Functions | |
| static void | st_endOfFrameCallback (FRAME_INFO *finfo, void *pvcamCtrlInst) | 
| Public Attributes | |
| 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 | 
| app::dev config to tell stdCamera not to expose temperature controls | |
| static constexpr bool | c_stdCamera_temp = false | 
| app::dev config to tell stdCamera not to expose temperature | |
| static constexpr bool | c_stdCamera_readoutSpeed | 
| app::dev config to tell stdCamera to expose readout speed controls | |
| static constexpr bool | c_stdCamera_vShiftSpeed | 
| app:dev config to tell stdCamera not to expose vertical shift speed control | |
| static constexpr bool | c_stdCamera_emGain | 
| app::dev config to tell stdCamera not to expose EM gain controls | |
| static constexpr bool | c_stdCamera_exptimeCtrl | 
| app::dev config to tell stdCamera 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 to expose FPS status | |
| static constexpr bool | c_stdCamera_synchro | 
| app::dev config to tell stdCamera to not expose synchro mode controls | |
| static constexpr bool | c_stdCamera_usesModes | 
| app:dev config to tell stdCamera not to expose mode controls | |
| static constexpr bool | c_stdCamera_usesROI = true | 
| app:dev config to tell stdCamera to expose ROI controls | |
| static constexpr bool | c_stdCamera_cropMode | 
| app:dev config to tell stdCamera to expose Crop Mode controls | |
| static constexpr bool | c_stdCamera_hasShutter | 
| app:dev config to tell stdCamera to expose shutter controls | |
| static constexpr bool | c_stdCamera_usesStateString | 
| app::dev confg to tell stdCamera to expose the state string property | |
| static constexpr bool | c_frameGrabber_flippable | 
| app:dev config to tell framegrabber this camera 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) | 
| void * | loadImageIntoStreamCopy (void *dest, void *src, size_t width, size_t height, size_t szof) | 
| Protected Attributes | |
| int16 | m_handle { -1 } | 
| Camera handle, set when camera is opened. | |
| std::string | m_camName | 
| Camera name, filled in as part of opening the camera. | |
| std::vector< port > | m_ports | 
| bool | m_8bit { false } | 
| bool | m_fpsSetted { false } | 
| Flag indicating that FPS was set, not exposure time. | |
| uns32 | m_circBuffBytes { 0 } | 
| uns8 * | m_circBuff { nullptr } | 
| FRAME_INFO | m_frameInfo | 
| sem_t | m_frSemaphore | 
| Semaphore used to signal that a frame is ready. | |
| sem_t | m_frDoneSemaphore | 
| Semaphore used to signal that a frame has been processed. | |
| uint64_t | m_callbacks { 0 } | 
| uint64_t | m_lastCallbacks { 0 } | 
| 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 | 
| Path to the cpusets mount. | |
| unsigned long | m_loopPause | 
| int | m_shutdown | 
| Flag to signal it's time to shutdown. When not 0, the main loop exits. | |
| 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. | |
| IMAGE * | m_imageStream | 
| The ImageStreamIO shared memory buffer. | |
| float | m_cbFPS | 
| The FPS used to configure the circular buffers. | |
| mx::sigproc::circularBufferIndex< timespec, cbIndexT > | m_atimes | 
| mx::sigproc::circularBufferIndex< timespec, cbIndexT > | m_wtimes | 
| std::vector< double > | m_atimesD | 
| std::vector< double > | m_wtimesD | 
| std::vector< double > | m_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_serialNumber | 
| The camera serial number. | |
| float | m_tempTol { 0.1 } | 
| Tolerance in degrees C to declare the temperature control locked. | |
| uint32_t | m_circBuffMaxBytes | 
| Max size in bytes of the circular buffer to allocate. Default is 0.5 GB. | |
| uint32_t | m_acqSleep { 5000 } | 
| The acquisition pause time, in ns, when no frame is ready.Default is 5000. | |
| 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 | |
| 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 Member Functions | |
| int | clearFSMAlert () | 
| Clear the FSM alert state. | |
| pvcamCtrl & | derived () | 
| Friends | |
| class | pvcamCtrl_test | 
| class | dev::stdCamera< pvcamCtrl > | 
| class | dev::frameGrabber< pvcamCtrl > | 
| class | dev::dssShutter< pvcamCtrl > | 
| class | dev::telemeter< pvcamCtrl > | 
| Logging | |
| static logManagerT | m_log | 
| void | logMessage (bufferPtrT &b) | 
| Handle a log message from the logging system. | |
| static int | log (const typename logT::messageT &msg, logPrioT level=logPrio::LOG_DEFAULT) | 
| Make a log entry. | |
| 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 | 
| 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, indiCallBack > | m_indiNewCallBacks | 
| Map to hold the NewProperty indiCallBacks for this App, with fast lookup by property name. | |
| std::unordered_map< std::string, indiCallBack > | m_indiSetCallBacks | 
| Map to hold the SetProperty indiCallBacks for this App, with fast lookup by property name. | |
| bool | m_allDefsReceived | 
| 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. | |
| 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, indiCallBack > | callBackValueType | 
| 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, bool > | callBackInsertResult | 
| Return type of insert on the indiCallBack map. | |
| static constexpr bool | m_useINDI | 
| Flag controlling whether INDI is used. If false, then no INDI code executes. | |
| indiDriver< MagAOXApp > * | m_indiDriver | 
| 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. | |
| 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. | |
| 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. | |
| 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. | |
| void | updatesIfChanged (pcf::IndiProperty &p, const std::vector< const char * > &els, const std::vector< T > &newVals, pcf::IndiProperty::PropertyStateType newState=pcf::IndiProperty::Ok) | 
| int | indiTargetUpdate (pcf::IndiProperty &localProperty, T &localTarget, const pcf::IndiProperty &remoteProperty, bool setBusy=true) | 
| Get the target element value from an new property. | |
| 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 | 
| 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 | 
| The INDI element name to monitor for this device's power state. | |
| std::string | m_powerTargetElement | 
| The INDI element name to monitor for this device's power state. | |
| unsigned long | m_powerOnWait | 
| Time in sec to wait for device to boot after power on. | |
| int | m_powerOnCounter | 
| int | m_powerState | 
| Current power state, 1=On, 0=Off, -1=Unk. | |
| int | m_powerTargetState | 
| 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) | |
| virtual int | onPowerOff () | 
| This method is called when the change to poweroff is detected. | |
| virtual int | whilePowerOff () | 
| This method is called while the power is off, once per FSM loop. | |
| 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 | 
| bool | m_stateAlert | 
| bool | m_gitAlert | 
| int | m_stateLogged | 
| 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 | |
| static MagAOXApp * | m_self | 
| 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. | |
The MagAO-X pvcam controller.
Definition at line 73 of file pvcamCtrl.hpp.
| struct MagAOX::app::pvcamCtrl::gain | 
Definition at line 163 of file pvcamCtrl.hpp.

| Class Members | ||
|---|---|---|
| int | bitDepth | |
| int | index | |
| string | name | |
| struct MagAOX::app::pvcamCtrl::port | 
Definition at line 180 of file pvcamCtrl.hpp.

| Class Members | ||
|---|---|---|
| int | index | |
| string | name | |
| vector< speed > | speeds | |
| int | value | |
| struct MagAOX::app::pvcamCtrl::speed | 
| 
 | inherited | 
Return type of insert on the indiCallBack map.
Definition at line 666 of file MagAOXApp.hpp.
| 
 | inherited | 
Iterator type of the indiCallBack map.
Definition at line 663 of file MagAOXApp.hpp.
| 
 | inherited | 
Value type of the indiCallBack map.
Definition at line 660 of file MagAOXApp.hpp.
| 
 | inherited | 
Definition at line 108 of file frameGrabber.hpp.
Definition at line 81 of file pvcamCtrl.hpp.
| 
 | inherited | 
The log manager type.
Definition at line 79 of file telemeter.hpp.
| 
 | inherited | 
The log manager type.
Definition at line 167 of file MagAOXApp.hpp.
Definition at line 93 of file pvcamCtrl.hpp.
Definition at line 82 of file pvcamCtrl.hpp.
Definition at line 80 of file pvcamCtrl.hpp.
Definition at line 83 of file pvcamCtrl.hpp.
| 
 | inherited | 
Definition at line 76 of file telemeter.hpp.
| 
 | inherited | 
Definition at line 164 of file MagAOXApp.hpp.
| 
 | inherited | 
Definition at line 100 of file frameGrabber.hpp.
| MagAOX::app::pvcamCtrl::pvcamCtrl | ( | ) | 
Default c'tor.
Definition at line 312 of file pvcamCtrl.hpp.
References MagAOX::app::dev::stdCamera< pvcamCtrl >::m_default_bin_x, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_default_bin_y, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_default_h, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_default_w, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_default_x, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_default_y, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_defaultReadoutSpeed, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTime, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTimeSet, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_full_h, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_full_w, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_full_x, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_full_y, MagAOX::app::MagAOXApp< true >::m_powerMgtEnabled, MagAOX::app::MagAOXApp< true >::m_powerOnWait, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedName, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedNameLabels, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedNames, and MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedNameSet.
| 
 | inlinenoexcept | 
D'tor, declared and defined for noexcept.
Definition at line 211 of file pvcamCtrl.hpp.
| 
 | staticprivateinherited | 
The handler called when SIGTERM, SIGQUIT, or SIGINT is received. Just a wrapper for handlerSigTerm.
| [in] | signum | specifies the signal. | 
| [in] | siginf | ignored by MagAOXApp | 
| [in] | ucont | ignored by MagAOXApp | 
Definition at line 386 of file MagAOXApp.hpp.
| int MagAOX::app::pvcamCtrl::acquireAndCheckValid | ( | ) | 
Definition at line 902 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), m_acqSleep, MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_currImageTimestamp, and m_frSemaphore.
| 
 | virtual | 
Implementation of the FSM for pvcamCtrl.
Implements MagAOX::app::MagAOXApp< true >.
Definition at line 444 of file pvcamCtrl.hpp.
References MagAOX::app::dev::dssShutter< pvcamCtrl >::appLogic(), connect(), MagAOX::app::stateCodes::CONNECTED, MagAOX::app::stateCodes::ERROR, FRAMEGRABBER_APP_LOGIC, FRAMEGRABBER_UPDATE_INDI, getTemp(), MagAOX::app::lock(), MagAOX::app::MagAOXApp< true >::log(), MagAOX::app::MagAOXApp< true >::m_indiMutex, MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_reconfig, MagAOX::app::stateCodes::NODEVICE, MagAOX::app::stateCodes::NOTCONNECTED, MagAOX::app::stateCodes::OPERATING, MagAOX::app::stateCodes::POWERON, MagAOX::app::MagAOXApp< true >::powerOnWaitElapsed(), MagAOX::app::MagAOXApp< true >::powerState(), MagAOX::app::MagAOXApp< true >::powerStateTarget(), MagAOX::app::stateCodes::READY, MagAOX::app::dev::stdCamera< pvcamCtrl >::recordCamera(), MagAOX::app::MagAOXApp< true >::state(), STDCAMERA_APP_LOGIC, STDCAMERA_UPDATE_INDI, and TELEMETER_APP_LOGIC.
| 
 | virtual | 
Shutdown the app.
Implements MagAOX::app::MagAOXApp< true >.
Definition at line 517 of file pvcamCtrl.hpp.
References MagAOX::app::dev::dssShutter< pvcamCtrl >::appShutdown(), FRAMEGRABBER_APP_SHUTDOWN, MagAOX::app::MagAOXApp< true >::log(), log_pvcam_software_error, m_handle, PL_ERR_LIBRARY_NOT_INITIALIZED, STDCAMERA_APP_SHUTDOWN, and TELEMETER_APP_SHUTDOWN.
| 
 | virtual | 
Startup function.
Implements MagAOX::app::MagAOXApp< true >.
Definition at line 417 of file pvcamCtrl.hpp.
References MagAOX::app::dev::dssShutter< pvcamCtrl >::appStartup(), FRAMEGRABBER_APP_STARTUP, MagAOX::app::MagAOXApp< true >::log(), m_frDoneSemaphore, m_frSemaphore, STDCAMERA_APP_STARTUP, and TELEMETER_APP_STARTUP.
| 
 | inherited | 
| 
 | inherited | 
Get the calibration directory.
Definition at line 1223 of file MagAOXApp.hpp.
| 
 | 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 260 of file MagAOXApp.hpp.
| int MagAOX::app::pvcamCtrl::checkNextROI | ( | ) | 
Check the next ROI.
Checks if the target values are valid and adjusts them to the closest valid values if needed.
Definition at line 630 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), and MagAOX::app::dev::stdCamera< pvcamCtrl >::m_nextROI.
| 
 | 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.
| 
 | 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.
| int MagAOX::app::pvcamCtrl::checkRecordTimes | ( | ) | 
Definition at line 1428 of file pvcamCtrl.hpp.
References MagAOX::app::dev::telemeter< pvcamCtrl >::checkRecordTimes().
| 
 | 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.
| [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.
| 
 | inherited | 
Empty function called at the end of the template list.
| [in] | ts | [unused] the timestamp that records are compared to | 
Definition at line 177 of file telemeter.hpp.
| 
 | inherited | 
Worker function to actually perform the record time checking logic.
Recursively calls itself until the variadic template list is exhausted.
| [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.
| 
 | 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 624 of file MagAOXApp.hpp.
| 
 | inherited | 
Get the config base file.
Definition at line 1218 of file MagAOXApp.hpp.
| 
 | inherited | 
Definition at line 241 of file frameGrabber.hpp.
| 
 | inherited | 
Get the config directory.
Definition at line 1213 of file MagAOXApp.hpp.
| 
 | 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.
| [in] | name | The name of the config value | 
| [in] | code | numeric code specifying the type | 
| [in] | value | the value read by the config system | 
| [in] | source | the source of the value. | 
Definition at line 366 of file MagAOXApp.hpp.
| 
 | inherited | 
Get the config name.
Definition at line 1207 of file MagAOXApp.hpp.
| int MagAOX::app::pvcamCtrl::configureAcquisition | ( | ) | 
Definition at line 690 of file pvcamCtrl.hpp.
References MagAOX::app::stateCodes::FAILURE, MagAOX::app::MagAOXApp< true >::log(), log_pvcam_software_error, m_8bit, m_circBuff, m_circBuffBytes, m_circBuffMaxBytes, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_currentROI, MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_dataType, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTime, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTimeSet, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_fps, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_fpsSet, m_fpsSetted, m_handle, MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_height, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_nextROI, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedName, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedNameSet, MagAOX::app::MagAOXApp< true >::m_shutdown, MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_width, MagAOX::app::dev::stdCamera< pvcamCtrl >::recordCamera(), st_endOfFrameCallback(), and MagAOX::app::MagAOXApp< true >::state().
| int MagAOX::app::pvcamCtrl::connect | ( | ) | 
Definition at line 970 of file pvcamCtrl.hpp.
References MagAOX::app::stateCodes::CONNECTED, fillSpeedTable(), MagAOX::app::MagAOXApp< true >::log(), flatlogs::logPrio::LOG_INFO, log_pvcam_software_error, m_camName, m_handle, m_serialNumber, MagAOX::app::stateCodes::NODEVICE, MagAOX::app::stateCodes::NOTCONNECTED, PL_ERR_LIBRARY_NOT_INITIALIZED, MagAOX::app::MagAOXApp< true >::state(), and MagAOX::app::MagAOXApp< true >::stateLogged().
Referenced by appLogic().
| 
 | inherited | 
Get the cpuset path.
Definition at line 1238 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Create the INDI FIFOs.
Changes permissions to max available and creates the FIFOs at the configured path.
Definition at line 910 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
| 
 | protectedinherited | 
Definition at line 549 of file stdCamera.hpp.
| 
 | inherited | 
Create a ReadOnly INDI Number property.
| [out] | prop | the property to create and setup | 
| [in] | propName | the 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 748 of file MagAOXApp.hpp.
| 
 | inherited | 
Create a standard ReadOnly INDI Text property, with at least one element.
| [out] | prop | the property to create and setup | 
| [in] | propName | the name of the property | 
| [in] | elName | the 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 713 of file MagAOXApp.hpp.
| 
 | inherited | 
Create a standard R/W INDI Number property with target and current elements.
| [out] | prop | the property to create and setup | 
| [in] | name | the name of the property | 
| [in] | min | the minimum value for the elements, applied to both target and current | 
| [in] | max | the minimum value for the elements, applied to both target and current | 
| [in] | step | the step size for the elements, applied to both target and current | 
| [in] | format | the _ 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 727 of file MagAOXApp.hpp.
| 
 | inherited | 
Create a standard R/W INDI switch with a single request element.
This switch is intended to function like a momentary switch.
| [out] | prop | the property to create and setup | 
| [in] | name | the 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 774 of file MagAOXApp.hpp.
| 
 | 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.
| [out] | prop | the property to create and setup | 
| [in] | name | the name of the property, | 
| [in] | elements | the 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 805 of file MagAOXApp.hpp.
| 
 | 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.
| [out] | prop | the property to create and setup | 
| [in] | name | the name of the property, | 
| [in] | elements | the element names to give to the switches | 
| [in] | elementLabels | the 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 787 of file MagAOXApp.hpp.
| 
 | inherited | 
Create a standard R/W INDI Text property with target and current elements.
| [out] | prop | the property to create and setup | 
| [in] | propName | the 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 700 of file MagAOXApp.hpp.
| 
 | 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.
| [out] | prop | the property to create and setup | 
| [in] | name | the 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 761 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
| 
 | protectedinherited | 
Definition at line 553 of file stdCamera.hpp.
| 
 | inlineprivateinherited | 
Definition at line 1044 of file stdCamera.hpp.
| 
 | inherited | 
Get the INDI control FIFO file name.
Definition at line 1267 of file MagAOXApp.hpp.
| 
 | inherited | 
Get the INDI input FIFO file name.
Definition at line 1255 of file MagAOXApp.hpp.
| 
 | inherited | 
Get the INDI output FIFO file name.
Definition at line 1261 of file MagAOXApp.hpp.
Definition at line 1270 of file pvcamCtrl.hpp.
References MagAOX::app::stateCodes::CONNECTED, MagAOX::app::MagAOXApp< true >::log(), log_pvcam_software_error, m_handle, and MagAOX::app::MagAOXApp< true >::state().
| void MagAOX::app::pvcamCtrl::endOfFrameCallback | ( | FRAME_INFO * | finfo | ) | 
Definition at line 1395 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), m_frameInfo, m_frDoneSemaphore, and m_frSemaphore.
Referenced by st_endOfFrameCallback().
| 
 | virtualinherited | 
The execute method implementing the standard main loop. Should not normally be overridden.
Performs final startup steps. That is:
Errors in the above steps will cause a process exit.
Then commences the main event loop. Conditions on entry to the main loop:
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.
Definition at line 290 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Execute framegrabbing.
Definition at line 261 of file frameGrabber.hpp.
| 
 | staticprotectedinherited | 
Thread starter, called by MagAOXApp::threadStart on thread construction. Calls fgThreadExec.
| [in] | o | a pointer to a frameGrabber instance (normally this) | 
Definition at line 258 of file frameGrabber.hpp.
| int MagAOX::app::pvcamCtrl::fillSpeedTable | ( | ) | 
Definition at line 1132 of file pvcamCtrl.hpp.
References MagAOX::app::stateCodes::CONNECTED, MagAOX::app::MagAOXApp< true >::log(), log_pvcam_software_error, m_handle, m_ports, MagAOX::app::stateCodes::READY, and MagAOX::app::MagAOXApp< true >::state().
Referenced by connect().
| float MagAOX::app::pvcamCtrl::fps | ( | ) | 
Definition at line 885 of file pvcamCtrl.hpp.
References MagAOX::app::dev::stdCamera< pvcamCtrl >::m_fps.
| int MagAOX::app::pvcamCtrl::getTemp | ( | ) | 
Definition at line 1322 of file pvcamCtrl.hpp.
References MagAOX::app::stateCodes::ERROR, MagAOX::app::MagAOXApp< true >::log(), log_pvcam_software_error, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_ccdTemp, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_ccdTempSetpt, m_handle, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_tempControlOnTarget, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_tempControlStatus, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_tempControlStatusStr, m_tempTol, MagAOX::app::stateCodes::OPERATING, MagAOX::app::MagAOXApp< true >::powerState(), MagAOX::app::MagAOXApp< true >::powerStateTarget(), and MagAOX::app::MagAOXApp< true >::state().
Referenced by appLogic().
| 
 | inherited | 
Get the value of the git alert flag.
Definition at line 595 of file MagAOXApp.hpp.
| 
 | 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.
| [in] | ipRecv | The property being sent. | 
Definition at line 926 of file MagAOXApp.hpp.
| 
 | 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.
| [in] | ipRecv | The property being requested. | 
Definition at line 932 of file MagAOXApp.hpp.
| 
 | 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.
| [in] | ipRecv | The property being changed. | 
Definition at line 942 of file MagAOXApp.hpp.
| 
 | privateinherited | 
Handles SIGTERM, SIGQUIT, and SIGINT. Sets m_shutdown to 1 and logs the signal.
| [in] | signum | specifies the signal. | 
| [in] | siginf | ignored by MagAOXApp | 
| [in] | ucont | ignored by MagAOXApp | 
Definition at line 392 of file MagAOXApp.hpp.
| 
 | inherited | 
Handler for the set INDI property request.
This is called by m_indiDriver's indiDriver::handleSetProperties.
| [in] | ipRecv | The property being changed. | 
Definition at line 951 of file MagAOXApp.hpp.
| 
 | inherited | 
| 
 | protectedinherited | 
Get the target element value from an new property.
| [out] | localProperty | The local property to update | 
| [out] | localTarget | The local value to update | 
| [in] | remoteProperty | the new property received | 
| [in] | setBusy | [optional] set property to busy if true | 
Definition at line 1048 of file MagAOXApp.hpp.
| 
 | 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 254 of file MagAOXApp.hpp.
| 
 | virtual | 
Definition at line 408 of file pvcamCtrl.hpp.
References loadConfigImpl(), MagAOX::app::MagAOXApp< true >::log(), flatlogs::logPrio::LOG_CRITICAL, and MagAOX::app::MagAOXApp< true >::m_shutdown.
| 
 | inherited | 
Load the device section from an application configurator.
| [in] | config | an application configuration from which to load values | 
Definition at line 120 of file telemeter.hpp.
| 
 | inherited | 
load the configuration system results
This should be called in derivedT::loadConfig as 
with appropriate error checking.
| [in] | config | the derived classes configurator | 
Definition at line 88 of file dssShutter.hpp.
| 
 | inherited | 
load the configuration system results
This should be called in derivedT::loadConfig as 
with appropriate error checking.
| [in] | config | the derived classes configurator | 
Definition at line 190 of file frameGrabber.hpp.
| 
 | inherited | 
load the configuration system results
This should be called in derivedT::loadConfig as 
with appropriate error checking.
| [in] | config | the derived classes configurator | 
Definition at line 545 of file stdCamera.hpp.
| int MagAOX::app::pvcamCtrl::loadConfigImpl | ( | mx::app::appConfigurator & | _config | ) | 
Implementation of loadConfig logic, separated for testing.
This is called by loadConfig().
| [in] | _config | an application configuration from which to load values | 
Definition at line 385 of file pvcamCtrl.hpp.
References FRAMEGRABBER_LOAD_CONFIG, MagAOX::app::dev::dssShutter< pvcamCtrl >::loadConfig(), MagAOX::app::MagAOXApp< true >::log(), flatlogs::logPrio::LOG_CRITICAL, m_acqSleep, m_circBuffMaxBytes, m_serialNumber, STDCAMERA_LOAD_CONFIG, and TELEMETER_LOAD_CONFIG.
Referenced by loadConfig().
Definition at line 927 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), log_pvcam_software_error, m_8bit, m_frDoneSemaphore, m_handle, MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_height, and MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_width.
| 
 | protectedinherited | 
Definition at line 265 of file frameGrabber.hpp.
| 
 | 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
Definition at line 504 of file MagAOXApp.hpp.
| 
 | staticinherited | 
Make a log entry.
Wrapper for logManager::log
| logT | the log entry type | 
| retval | the value returned by this method. | 
| [in] | msg | the message to log | 
| [in] | level | [optional] the log level. The default is used if not specified. | 
Definition at line 337 of file MagAOXApp.hpp.
| 
 | staticinherited | 
Make a log entry.
Wrapper for logManager::log
| logT | the log entry type | 
| retval | the value returned by this method. | 
| [in] | level | [optional] the log level. The default is used if not specified. | 
Definition at line 350 of file MagAOXApp.hpp.
| 
 | 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 359 of file MagAOXApp.hpp.
| 
 | inherited | 
Get the loop pause time.
Definition at line 1243 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The callback called by the static version, to actually process the FSM Alert Clear request.
| [in] | ipRecv | the INDI property sent with the new property request. | 
Definition at line 1105 of file MagAOXApp.hpp.
| 
 | inherited | 
Callback to process a NEW cropMode request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 849 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW EM gain request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 753 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW exposure time request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 773 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW fps request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 793 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW mode request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 821 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW readout speed request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 713 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW reconfigure request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 829 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW bin_x request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 889 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW bin_y request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 897 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_check request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 917 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_default request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 977 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_full request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 945 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_fullbin request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 953 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_h request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 881 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_last request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 969 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_loadlast request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 961 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_set request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 937 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_w request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 873 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_x request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 857 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW roi_y request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 865 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW shutter request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 997 of file stdCamera.hpp.
| 
 | inherited | 
The callback function for stdCamera properties.
Dispatches to the relevant handler
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 653 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW synchro request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 813 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW CCD temp request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 673 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW CCD temp control request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 693 of file stdCamera.hpp.
| 
 | inherited | 
Callback to process a NEW vshift speed request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 733 of file stdCamera.hpp.
| 
 | inherited | 
Actions on power off.
This should be called in derivedT::appPowerOff as 
with appropriate error checking.
Definition at line 137 of file dssShutter.hpp.
| 
 | inherited | 
On power off, sets m_reconfig to true.
This should be called in derivedT::onPowerOff as 
with appropriate error checking.
Definition at line 227 of file frameGrabber.hpp.
| 
 | inherited | 
Actions on power off.
This should be called from the derived's onPowerOff() as in
with appropriate error checking.
The INDI mutex should be locked before calling.
Definition at line 602 of file stdCamera.hpp.
| 
 | protectedvirtualinherited | 
This method is called when the change to poweroff is detected.
Reimplemented in MagAOX::app::alpaoCtrl, MagAOX::app::bmcCtrl, MagAOX::app::irisaoCtrl, and MagAOX::app::zaberLowLevel.
Definition at line 1150 of file MagAOXApp.hpp.
| 
 | inherited | 
Open the shutter.
Do not lock the mutex before calling this.
Definition at line 164 of file dssShutter.hpp.
| 
 | protectedinherited | 
| 
 | staticprotectedinherited | 
Open thread starter function.
| [in] | d | pointer to this | 
Definition at line 197 of file dssShutter.hpp.
| int MagAOX::app::pvcamCtrl::powerOnDefaults | ( | ) | 
Definition at line 550 of file pvcamCtrl.hpp.
References MagAOX::app::dev::stdCamera< pvcamCtrl >::m_defaultReadoutSpeed, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTime, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTimeSet, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedName, and MagAOX::app::dev::stdCamera< pvcamCtrl >::m_readoutSpeedNameSet.
| 
 | 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.
Definition at line 1166 of file MagAOXApp.hpp.
| 
 | inherited | 
Returns the current power state.
If power management is not enabled, this always returns 1=On.
Definition at line 1176 of file MagAOXApp.hpp.
| 
 | inherited | 
Returns the target power state.
If power management is not enabled, this always returns 1=On.
Definition at line 1185 of file MagAOXApp.hpp.
| int MagAOX::app::pvcamCtrl::reconfig | ( | ) | 
Definition at line 961 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), log_pvcam_software_error, and m_handle.
| 
 | inherited | 
Definition at line 1039 of file stdCamera.hpp.
| 
 | inherited | 
Definition at line 296 of file frameGrabber.hpp.
| 
 | inline | 
Definition at line 1438 of file pvcamCtrl.hpp.
References MagAOX::app::dev::frameGrabber< pvcamCtrl >::recordFGTimings().
| int MagAOX::app::pvcamCtrl::recordTelem | ( | const telem_stdcam * | ) | 
Definition at line 1433 of file pvcamCtrl.hpp.
References MagAOX::app::dev::stdCamera< pvcamCtrl >::recordCamera().
| 
 | 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.
| [out] | prop | the property to register | 
| [in] | propName | the name of the property | 
| [in] | propType | the type of the property | 
| [in] | propPerm | the permissions of the property | 
| [in] | propState | the state of the property | 
| [in] | propRule | the switch rule type | 
| 
 | 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.
| [out] | prop | the property to register | 
| [in] | propName | the name of the property | 
| [in] | propType | the type of the property | 
| [in] | propPerm | the permissions of the property | 
| [in] | propState | the state of the property | 
| 
 | 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.
| [in] | prop | the property to register, must be fully set up | 
| 
 | inherited | 
Register an INDI property which is read only.
This version requires the property be fully set up.
| [in] | prop | the property to register, must be completely setup | 
Definition at line 821 of file MagAOXApp.hpp.
| 
 | inherited | 
Register an INDI property which is read only.
This verison sets up the INDI property according to the arguments.
| [out] | prop | the property to register, will be configured | 
| [in] | propName | the name of the property | 
| [in] | propType | the type of the property | 
| [in] | propPerm | the permissions of the property | 
| [in] | propState | the state of the property | 
Definition at line 831 of file MagAOXApp.hpp.
| 
 | inherited | 
Register an INDI property which is monitored for updates from others.
| [out] | prop | the property to register | 
| [in] | devName | the device which owns this property | 
| [in] | propName | the name of the property | 
Definition at line 898 of file MagAOXApp.hpp.
| 
 | inherited | 
Get the secrets path.
Definition at line 1233 of file MagAOXApp.hpp.
| 
 | inherited | 
Definition at line 920 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Send a newProperty command to another device (using the INDI Client interface)
| [in] | ipSend | The property to send a "new" INDI command for | 
Definition at line 1071 of file MagAOXApp.hpp.
| 
 | 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.
| [in] | ipSend | The property to send a "new" INDI command for | 
| [in] | el | The element of the property to change | 
| [in] | newVal | The value to request for the element. | 
Definition at line 1061 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Send a new property commmand for a standard toggle switch.
| [in] | device | The device name | 
| [in] | property | The property name | 
| [in] | onoff | Switch state to send: true = on, false = off | 
Definition at line 1078 of file MagAOXApp.hpp.
| 
 | inherited | 
The callback called by the static version, to actually process the new request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 251 of file dssShutter.hpp.
| 
 | inherited | 
The callback called by the static version, to actually process the new request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 268 of file dssShutter.hpp.
| 
 | inherited | 
The callback called by the static version, to actually process the new request.
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 284 of file dssShutter.hpp.
| 
 | 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.
| 
 | 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.
| 
 | 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.
| [in] | argc | standard command line result specifying number of arguments in argv | 
| [in] | argv | standard command line result containing the arguments. | 
Definition at line 232 of file MagAOXApp.hpp.
| int MagAOX::app::pvcamCtrl::setEMGain | ( | ) | 
Definition at line 583 of file pvcamCtrl.hpp.
| 
 | 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.
| 
 | 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.
| 
 | 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
Definition at line 463 of file MagAOXApp.hpp.
| 
 | 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
Definition at line 472 of file MagAOXApp.hpp.
| int MagAOX::app::pvcamCtrl::setExpTime | ( | ) | 
Definition at line 588 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), flatlogs::logPrio::LOG_INFO, log_pvcam_software_error, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTimeSet, m_handle, and MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_reconfig.
Referenced by setFPS().
| 
 | 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.
| 
 | 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.
| int MagAOX::app::pvcamCtrl::setFPS | ( | ) | 
Definition at line 623 of file pvcamCtrl.hpp.
References MagAOX::app::dev::stdCamera< pvcamCtrl >::m_expTimeSet, MagAOX::app::dev::stdCamera< pvcamCtrl >::m_fpsSet, m_fpsSetted, and setExpTime().
| 
 | 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.
| 
 | 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.
| int MagAOX::app::pvcamCtrl::setNextROI | ( | ) | 
Definition at line 677 of file pvcamCtrl.hpp.
References MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_reconfig.
| 
 | 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.
| 
 | 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.
| int MagAOX::app::pvcamCtrl::setReadoutSpeed | ( | ) | 
Definition at line 571 of file pvcamCtrl.hpp.
References MagAOX::app::dev::frameGrabber< pvcamCtrl >::m_reconfig.
| 
 | 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.
| 
 | 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.
Sets the shutter state, via call to dssShutter::setShutterState(int) [stdCamera interface].
Definition at line 684 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), MagAOX::app::dev::stdCamera< pvcamCtrl >::recordCamera(), and MagAOX::app::dev::dssShutter< pvcamCtrl >::setShutterState().
| 
 | 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.
| 
 | 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.
| 
 | inherited | 
Change shutter state.
Sets m_doOpen or m_doShut and signals the appropriate thread.
| sh | Desired shutter state. 0 for shut,1 for open | 
Definition at line 156 of file dssShutter.hpp.
| 
 | privateinherited | 
Sets the handler for SIGTERM, SIGQUIT, and SIGINT.
Definition at line 383 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | 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.
| int MagAOX::app::pvcamCtrl::setTempControl | ( | ) | 
Definition at line 561 of file pvcamCtrl.hpp.
| 
 | 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.
| 
 | 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.
| int MagAOX::app::pvcamCtrl::setTempSetPt | ( | ) | 
Definition at line 566 of file pvcamCtrl.hpp.
| 
 | 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.
| 
 | 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.
| 
 | 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 244 of file MagAOXApp.hpp.
| 
 | virtual | 
Definition at line 343 of file pvcamCtrl.hpp.
References FRAMEGRABBER_SETUP_CONFIG, MagAOX::app::dev::dssShutter< pvcamCtrl >::setupConfig(), STDCAMERA_SETUP_CONFIG, and TELEMETER_SETUP_CONFIG.
| 
 | inherited | 
Setup an application configurator for the device section.
| [in] | config | an application configuration to setup | 
Definition at line 112 of file telemeter.hpp.
| 
 | inherited | 
Setup the configuration system.
This should be called in derivedT::setupConfig as 
with appropriate error checking.
| [out] | config | the derived classes configurator | 
Definition at line 78 of file dssShutter.hpp.
| 
 | inherited | 
Setup the configuration system.
This should be called in derivedT::setupConfig as 
with appropriate error checking.
| [out] | config | the derived classes configurator | 
Definition at line 180 of file frameGrabber.hpp.
| 
 | inherited | 
Setup the configuration system.
This should be called in derivedT::setupConfig as 
with appropriate error checking.
| [out] | config | the derived classes configurator | 
Definition at line 535 of file stdCamera.hpp.
| int MagAOX::app::pvcamCtrl::setVShiftSpeed | ( | ) | 
Definition at line 578 of file pvcamCtrl.hpp.
| 
 | 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.
| 
 | 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.
| 
 | inherited | 
Shut the shutter.
Do not lock the mutex before calling this.
Definition at line 172 of file dssShutter.hpp.
| 
 | inherited | 
Get the value of the shutdown flag.
Definition at line 1249 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
| 
 | staticprotectedinherited | 
Shut thread starter function.
| [in] | d | pointer to this | 
Definition at line 215 of file dssShutter.hpp.
| 
 | static | 
Definition at line 1390 of file pvcamCtrl.hpp.
References endOfFrameCallback(), and MagAOX::app::MagAOXApp< true >::log().
Referenced by configureAcquisition().
| 
 | staticprotectedinherited | 
The static callback function to be registered for requesting to clear the FSM alert.
| [in] | app | a pointer to this, will be static_cast-ed to MagAOXApp. | 
| [in] | ipRecv | the INDI property sent with the new property request. | 
Definition at line 1094 of file MagAOXApp.hpp.
| 
 | staticinherited | 
The static callback function to be registered for stdCamera properties.
Calls newCallback_stdCamera
| [in] | app | a pointer to this, will be static_cast-ed to derivedT. | 
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 642 of file stdCamera.hpp.
| 
 | staticinherited | 
The static callback function to be registered for shutter power channel changes.
| [in] | app | a pointer to this, will be static_cast-ed to derivedT. | 
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 242 of file dssShutter.hpp.
| 
 | staticinherited | 
The static callback function to be registered for shutter sensor channel changes.
| [in] | app | a pointer to this, will be static_cast-ed to derivedT. | 
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 259 of file dssShutter.hpp.
| 
 | staticinherited | 
The static callback function to be registered for shutter trigger channel changes.
| [in] | app | a pointer to this, will be static_cast-ed to derivedT. | 
| [in] | ipRecv | the INDI property sent with the the new property request. | 
Definition at line 275 of file dssShutter.hpp.
| int MagAOX::app::pvcamCtrl::startAcquisition | ( | ) | 
Definition at line 890 of file pvcamCtrl.hpp.
References MagAOX::app::MagAOXApp< true >::log(), flatlogs::logPrio::LOG_INFO, log_pvcam_software_error, m_circBuff, m_circBuffBytes, and m_handle.
| 
 | protectedinherited | 
Start INDI Communications.
Definition at line 917 of file MagAOXApp.hpp.
| 
 | inherited | 
| 
 | inherited | 
Set the current state code.
| [in] | s | The new application state | 
| [in] | stateAlert | [optional] flag to set the alert state of the FSM property. | 
Definition at line 581 of file MagAOXApp.hpp.
| 
 | inherited | 
Get the value of the state alert flag.
Definition at line 589 of file MagAOXApp.hpp.
| 
 | 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:
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.
Definition at line 614 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | 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.
| 
 | 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.
| 
 | 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.
| 
 | inherited | 
| 
 | inherited | 
Make a telemetry recording.
Wrapper for logManager::log, which updates telT::lastRecord.
| logT | the log entry type | 
| retval | the value returned by this method. | 
| [in] | msg | the data to log | 
Definition at line 95 of file telemeter.hpp.
| 
 | 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:
 where impl is the derived class, and mThreadStart and myThreadExec are members of impl.
| [out] | thrd | The 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] | thrdPrio | The r/t priority to set for this thread | 
| [in] | cpuset | the cpuset to place this thread on. Ignored if "". | 
| [in] | thrdName | The name of the thread (just for logging) | 
| [in] | thrdThis | The thispointer to pass to the thread starter function | 
| [in] | thrdStart | The thread starting function, a static function taking a thispointer as argument. | 
Definition at line 538 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Remove the PID file.
Definition at line 507 of file MagAOXApp.hpp.
| 
 | 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.
| p | [in/out] The property containing the element to possibly update | |
| [in] | el | The element name | 
| [in] | newVal | the new value | 
Definition at line 981 of file MagAOXApp.hpp.
| 
 | 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.
| p | [in/out] The property containing the element to possibly update | |
| [in] | el | Beginning of each element name | 
| [in] | newVals | the new values | 
| [in] | ipState | [optional] the new state | 
Definition at line 1010 of file MagAOXApp.hpp.
| 
 | 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.
| p | [in/out] The property containing the element to possibly update | |
| [in] | el | The element name | 
| [in] | newVal | the new value | 
Definition at line 964 of file MagAOXApp.hpp.
| 
 | 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.
| p | [in/out] The property containing the element to possibly update | |
| [in] | els | String vector of element names | 
| [in] | newVals | the new values | 
| [in] | newState | [optional] The state of the property | 
Definition at line 1027 of file MagAOXApp.hpp.
| 
 | inherited | 
Update the INDI properties for this device controller.
You should call this once per main loop. It is not called automatically.
Definition at line 288 of file frameGrabber.hpp.
| 
 | inherited | 
Update the INDI properties for this device controller.
You should call this once per main loop. It is not called automatically.
Definition at line 1031 of file stdCamera.hpp.
| 
 | protectedinherited | 
| p | [in/out] The property containing the element to possibly update | |
| [in] | els | String vector of element names | 
| [in] | newVals | the new values | 
| [in] | newState | [optional] The state of the property | 
Definition at line 1035 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Update an INDI switch element value if it has changed.
Will only peform a SetProperty if the new element switch state has changed, or the propery state has changed.
| p | [in/out] The property containing the element to possibly update | |
| [in] | el | The element name | 
| [in] | newVal | the new value | 
Definition at line 992 of file MagAOXApp.hpp.
| 
 | inherited | 
Actions while powered off.
This should be called in derivedT::whilePowerOff as 
with appropriate error checking.
Definition at line 149 of file dssShutter.hpp.
| 
 | inherited | 
Actions while powered off.
This should be called from the derived's whilePowerOff() as in
with appropriate error checking.
Definition at line 615 of file stdCamera.hpp.
| 
 | protectedvirtualinherited | 
This method is called while the power is off, once per FSM loop.
Reimplemented in MagAOX::app::alpaoCtrl, MagAOX::app::bmcCtrl, MagAOX::app::irisaoCtrl, and MagAOX::app::zaberLowLevel.
Definition at line 1157 of file MagAOXApp.hpp.
| 
 | friend | 
Definition at line 86 of file pvcamCtrl.hpp.
| 
 | friend | 
Definition at line 86 of file pvcamCtrl.hpp.
| 
 | friend | 
Definition at line 86 of file pvcamCtrl.hpp.
| 
 | friend | 
Definition at line 86 of file pvcamCtrl.hpp.
Definition at line 86 of file pvcamCtrl.hpp.
app:dev config to tell framegrabber this camera can not be flipped
Definition at line 137 of file pvcamCtrl.hpp.
app:dev config to tell stdCamera to expose Crop Mode controls
Definition at line 128 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera not to expose EM gain controls
Definition at line 110 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera to expose exposure time controls
Definition at line 113 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera to expose FPS status
Definition at line 118 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera to expose FPS controls
Definition at line 116 of file pvcamCtrl.hpp.
app:dev config to tell stdCamera to expose shutter controls
Definition at line 131 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera to expose readout speed controls
Definition at line 104 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera to not expose synchro mode controls
Definition at line 120 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera not to expose temperature
Definition at line 102 of file pvcamCtrl.hpp.
app::dev config to tell stdCamera not to expose temperature controls
Definition at line 99 of file pvcamCtrl.hpp.
app:dev config to tell stdCamera not to expose mode controls
Definition at line 123 of file pvcamCtrl.hpp.
app:dev config to tell stdCamera to expose ROI controls
Definition at line 126 of file pvcamCtrl.hpp.
app::dev confg to tell stdCamera to expose the state string property
Definition at line 134 of file pvcamCtrl.hpp.
app:dev config to tell stdCamera not to expose vertical shift speed control
Definition at line 107 of file pvcamCtrl.hpp.
Definition at line 191 of file pvcamCtrl.hpp.
Referenced by configureAcquisition(), and loadImageIntoStream().
| 
 | protected | 
The acquisition pause time, in ns, when no frame is ready.Default is 5000.
Definition at line 155 of file pvcamCtrl.hpp.
Referenced by acquireAndCheckValid(), and loadConfigImpl().
| 
 | protectedinherited | 
Definition at line 349 of file stdCamera.hpp.
| 
 | protectedinherited | 
Flag indicating that all registered Set properties have been updated since last Get.
Definition at line 681 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Definition at line 147 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 150 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The base path of the MagAO-X system.
Definition at line 170 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The path to calibration files for MagAOX.
Definition at line 178 of file MagAOXApp.hpp.
| 
 | protected | 
Definition at line 203 of file pvcamCtrl.hpp.
| 
 | protectedinherited | 
Map holding the possible camera mode configurations.
Definition at line 297 of file stdCamera.hpp.
| 
 | protected | 
Camera name, filled in as part of opening the camera.
Definition at line 161 of file pvcamCtrl.hpp.
Referenced by connect().
| 
 | protectedinherited | 
The FPS used to configure the circular buffers.
Definition at line 145 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The current temperature, in C.
Definition at line 316 of file stdCamera.hpp.
| 
 | protectedinherited | 
The desired temperature, in C.
Definition at line 318 of file stdCamera.hpp.
Definition at line 196 of file pvcamCtrl.hpp.
Referenced by configureAcquisition(), and startAcquisition().
| 
 | protected | 
Definition at line 195 of file pvcamCtrl.hpp.
Referenced by configureAcquisition(), and startAcquisition().
| 
 | protectedinherited | 
Length of the circular buffer, in frames.
Definition at line 120 of file frameGrabber.hpp.
| 
 | protected | 
Max size in bytes of the circular buffer to allocate. Default is 0.5 GB.
Definition at line 152 of file pvcamCtrl.hpp.
Referenced by configureAcquisition(), and loadConfigImpl().
| 
 | protectedinherited | 
The name of a base config class for this app (minus .conf).
Definition at line 176 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The path to configuration files for MagAOX.
Definition at line 174 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The name of the configuration file (minus .conf).
Definition at line 172 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | protectedinherited | 
Status of crop mode ROIs, if enabled for this camera.
Definition at line 498 of file stdCamera.hpp.
| 
 | protectedinherited | 
Desired status of crop mode ROIs, if enabled for this camera.
Definition at line 499 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 426 of file stdCamera.hpp.
| 
 | protectedinherited | 
The timestamp of the current image.
Definition at line 139 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The ImageStreamIO type code.
Definition at line 133 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Power-on ROI x binning.
Definition at line 458 of file stdCamera.hpp.
| 
 | protectedinherited | 
Power-on ROI y binning.
Definition at line 459 of file stdCamera.hpp.
| 
 | protectedinherited | 
Power-on ROI height.
Definition at line 457 of file stdCamera.hpp.
| 
 | protectedinherited | 
Power-on ROI width.
Definition at line 456 of file stdCamera.hpp.
| 
 | protectedinherited | 
Power-on ROI center x coordinate.
Definition at line 454 of file stdCamera.hpp.
| 
 | protectedinherited | 
Power-on ROI center y coordinate.
Definition at line 455 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 126 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The default readout speed of the camera.
Definition at line 303 of file stdCamera.hpp.
| 
 | protectedinherited | 
The default readout speed of the camera.
Definition at line 304 of file stdCamera.hpp.
| 
 | protectedinherited | 
The device controlling this shutter's digital I/O.
Definition at line 47 of file dssShutter.hpp.
| 
 | 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.
| 
 | 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.
| 
 | 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.
| 
 | protectedinherited | 
Full path name of the INDI driver input FIFO.
Definition at line 684 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Full path name of the INDI driver output FIFO.
Definition at line 687 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Definition at line 156 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 155 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 154 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The camera's current EM gain (if available).
Definition at line 352 of file stdCamera.hpp.
| 
 | protectedinherited | 
The camera's EM gain, as set by the user.
Definition at line 353 of file stdCamera.hpp.
| 
 | 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.
| 
 | 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.
| 
 | protectedinherited | 
The current exposure time, in seconds.
Definition at line 370 of file stdCamera.hpp.
| 
 | protectedinherited | 
The exposure time, in seconds, as set by user.
Definition at line 371 of file stdCamera.hpp.
| 
 | protectedinherited | 
The cpuset to assign the framegrabber thread to. Not used if empty, the default.
Definition at line 118 of file frameGrabber.hpp.
| 
 | protectedinherited | 
A separate thread for the actual framegrabbings.
Definition at line 255 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The ID of the framegrabber thread.
Definition at line 251 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Synchronizer for thread startup, to allow priority setting to finish.
Definition at line 249 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Priority of the framegrabber thread, should normally be > 00.
Definition at line 117 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The property to hold the f.g. thread details.
Definition at line 253 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The current FPS.
Definition at line 377 of file stdCamera.hpp.
| 
 | protectedinherited | 
The commanded fps, as set by user.
Definition at line 378 of file stdCamera.hpp.
Flag indicating that FPS was set, not exposure time.
Definition at line 193 of file pvcamCtrl.hpp.
Referenced by configureAcquisition(), and setFPS().
| 
 | protected | 
Definition at line 198 of file pvcamCtrl.hpp.
Referenced by endOfFrameCallback().
| 
 | protected | 
Semaphore used to signal that a frame has been processed.
Definition at line 201 of file pvcamCtrl.hpp.
Referenced by appStartup(), endOfFrameCallback(), and loadImageIntoStream().
| 
 | protected | 
Semaphore used to signal that a frame is ready.
Definition at line 200 of file pvcamCtrl.hpp.
Referenced by acquireAndCheckValid(), appStartup(), and endOfFrameCallback().
| 
 | protectedinherited | 
The x-binning in the full ROI.
Definition at line 465 of file stdCamera.hpp.
| 
 | protectedinherited | 
The y-binning in the full ROI.
Definition at line 466 of file stdCamera.hpp.
| 
 | protectedinherited | 
The current-binning full ROI height.
Definition at line 471 of file stdCamera.hpp.
| 
 | protectedinherited | 
The current-binning full ROI width.
Definition at line 470 of file stdCamera.hpp.
| 
 | protectedinherited | 
The current-binning full ROI center x coordinate.
Definition at line 468 of file stdCamera.hpp.
| 
 | protectedinherited | 
The current-binning full ROI center y coordinate.
Definition at line 469 of file stdCamera.hpp.
| 
 | protectedinherited | 
The full ROI height.
Definition at line 464 of file stdCamera.hpp.
| 
 | protectedinherited | 
The full ROI width.
Definition at line 463 of file stdCamera.hpp.
| 
 | protectedinherited | 
The full ROI center x coordinate.
Definition at line 461 of file stdCamera.hpp.
| 
 | protectedinherited | 
The full ROI center y coordinate.
Definition at line 462 of file stdCamera.hpp.
| 
 | privateinherited | 
Definition at line 564 of file MagAOXApp.hpp.
| 
 | protected | 
Camera handle, set when camera is opened.
Definition at line 159 of file pvcamCtrl.hpp.
Referenced by appShutdown(), configureAcquisition(), connect(), dumpEnum(), fillSpeedTable(), getTemp(), loadImageIntoStream(), reconfig(), setExpTime(), and startAcquisition().
| 
 | protectedinherited | 
The height of the image, once deinterlaced etc.
Definition at line 131 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The ImageStreamIO shared memory buffer.
Definition at line 143 of file frameGrabber.hpp.
| 
 | inherited | 
The INDI driver wrapper. Constructed and initialized by execute, which starts and stops communications.
Definition at line 641 of file MagAOXApp.hpp.
| 
 | inherited | 
Mutex for locking INDI communications.
Definition at line 644 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | protectedinherited | 
indi Property to clear an FSM alert.
Definition at line 1087 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Property used to toggle crop mode on and off.
Definition at line 501 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 359 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 380 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 382 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to report the current frame size.
Definition at line 276 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Property used to preset the full ROI dimensions.
Definition at line 480 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to report the current mode.
Definition at line 405 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to monitor the shutter's power state.
Definition at line 231 of file dssShutter.hpp.
| 
 | protectedinherited | 
INDI property used to communicate power state.
Definition at line 1143 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Definition at line 356 of file stdCamera.hpp.
| 
 | protectedinherited | 
Request switch which forces the framegrabber to go through the reconfigure process.
Definition at line 408 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to set the ROI x binning.
Definition at line 477 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to set the ROI y binning.
Definition at line 478 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to trigger checking the target ROI.
Definition at line 482 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to trigger setting the default and startup ROI.
Definition at line 490 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to trigger setting the full ROI.
Definition at line 486 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to trigger setting the full in current binning ROI.
Definition at line 487 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to set the ROI height.
Definition at line 476 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to trigger setting the last ROI.
Definition at line 489 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to trigger loading the last ROI as the target.
Definition at line 488 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to trigger setting the ROI.
Definition at line 484 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to set the ROI width.
Definition at line 475 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to set the ROI x center coordinate.
Definition at line 473 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to set the ROI x center coordinate.
Definition at line 474 of file stdCamera.hpp.
| 
 | protectedinherited | 
Property used to monitor the shutter's hall sensor.
Definition at line 232 of file dssShutter.hpp.
| 
 | protectedinherited | 
Property used to report the shmim buffer name.
Definition at line 274 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Property used to control the shutter, a switch.
Definition at line 512 of file stdCamera.hpp.
| 
 | protectedinherited | 
State of the shutter. 0 = shut, 1 = open, -1 = unknown.
Property to report shutter status
Definition at line 511 of file stdCamera.hpp.
| 
 | protectedinherited | 
indi Property to report the application state.
Definition at line 1084 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Definition at line 520 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 393 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 327 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 328 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 329 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 278 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Property used to monitor and set the shutter's trigger.
Definition at line 233 of file dssShutter.hpp.
| 
 | protectedinherited | 
Definition at line 357 of file stdCamera.hpp.
| 
 | 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.
| 
 | protected | 
Definition at line 204 of file pvcamCtrl.hpp.
| 
 | protectedinherited | 
Definition at line 428 of file stdCamera.hpp.
| 
 | protectedinherited | 
Maximum length of the latency measurement circular buffers.
Definition at line 122 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Maximum time of the latency meaurement circular buffers.
Definition at line 124 of file frameGrabber.hpp.
| 
 | staticinherited | 
Definition at line 327 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | protectedinherited | 
Definition at line 161 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The configurable maximum EM gain. To be enforced in derivedT.
Definition at line 354 of file stdCamera.hpp.
| 
 | protectedinherited | 
The maximum exposure time, used for INDI attributes.
Definition at line 367 of file stdCamera.hpp.
| 
 | protectedinherited | 
The maximum FPS, used for INDI attributes.
Definition at line 374 of file stdCamera.hpp.
| 
 | inherited | 
The maximum interval, in seconds, between telemetry records. Default is 10.0 seconds.
Definition at line 83 of file telemeter.hpp.
| 
 | protectedinherited | 
Definition at line 447 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 451 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 443 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 439 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 431 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 435 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 313 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 166 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 160 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The minimum exposure time, used for INDI attributes.
Definition at line 366 of file stdCamera.hpp.
| 
 | protectedinherited | 
The minimum FPS, used for INDI attributes.
Definition at line 373 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 446 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 450 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 442 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 438 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 430 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 434 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 312 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 165 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 158 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 163 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 168 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The current mode name.
Definition at line 401 of file stdCamera.hpp.
| 
 | protectedinherited | 
The mode to be set by the next reconfiguration.
Definition at line 403 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 427 of file stdCamera.hpp.
| 
 | protectedinherited | 
The opening thread.
Definition at line 194 of file dssShutter.hpp.
| 
 | protectedinherited | 
Open thread PID.
Definition at line 190 of file dssShutter.hpp.
| 
 | protectedinherited | 
Initialization flag for the open thread.
Definition at line 188 of file dssShutter.hpp.
| 
 | protectedinherited | 
The property to hold the open thread details.
Definition at line 192 of file dssShutter.hpp.
| 
 | protectedinherited | 
This process's PID.
Definition at line 488 of file MagAOXApp.hpp.
| 
 | protected | 
Definition at line 189 of file pvcamCtrl.hpp.
Referenced by fillSpeedTable().
| 
 | protectedinherited | 
The channel controlling this shutter's power.
Definition at line 45 of file dssShutter.hpp.
| 
 | protectedinherited | 
The INDI property name of the channel controlling this device's power.
Definition at line 1129 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The device controlling this shutter's power.
Definition at line 44 of file dssShutter.hpp.
| 
 | protectedinherited | 
The INDI device name of the power controller.
Definition at line 1128 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The INDI element name to monitor for this device's power state.
Definition at line 1130 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Flag controls whether power mgt is used. Set this in the constructor of a derived app. If true, then if after loadConfig the powerDevice and powerChannel are empty, then the app will exit with a critical error.
Definition at line 1123 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | protectedinherited | 
Time in sec to wait for device to boot after power on.
Definition at line 1133 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The current power state, -1 is unknown, 0 is off, 1 is on.
Definition at line 56 of file dssShutter.hpp.
| 
 | protectedinherited | 
Current power state, 1=On, 0=Off, -1=Unk.
Definition at line 1140 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The INDI element name to monitor for this device's power state.
Definition at line 1131 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Current target power state, 1=On, 0=Off, -1=Unk.
Definition at line 1141 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
The current readout speed name.
Definition at line 340 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 338 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 337 of file stdCamera.hpp.
| 
 | protectedinherited | 
The user requested readout speed name, to be set by derived()
Definition at line 341 of file stdCamera.hpp.
| 
 | protectedinherited | 
Flag to set if a camera reconfiguration requires a framegrabber reset.
Definition at line 141 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Path to the secrets directory, where passwords, etc, are stored.
Definition at line 182 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | protectedinherited | 
The channel reading this shutter's sensor.
Definition at line 48 of file dssShutter.hpp.
| 
 | protectedinherited | 
The current sensor state, -1 is unknown, 0 is shut, 1 is open.
Definition at line 58 of file dssShutter.hpp.
| 
 | protected | 
The camera serial number.
Definition at line 147 of file pvcamCtrl.hpp.
Referenced by connect(), and loadConfigImpl().
| 
 | 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.
| 
 | protectedinherited | 
Flag to signal it's time to shutdown. When not 0, the main loop exits.
Definition at line 196 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Definition at line 509 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 508 of file stdCamera.hpp.
| 
 | 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.
| 
 | 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.
| 
 | protectedinherited | 
The shutting thread.
Definition at line 212 of file dssShutter.hpp.
| 
 | protectedinherited | 
Shut thread PID.
Definition at line 208 of file dssShutter.hpp.
| 
 | protectedinherited | 
Initialization flag for the shut thread.
Definition at line 206 of file dssShutter.hpp.
| 
 | protectedinherited | 
The property to hold the shut thread details.
Definition at line 210 of file dssShutter.hpp.
| 
 | protectedinherited | 
The camera mode to load during first init after a power-on.
Definition at line 299 of file stdCamera.hpp.
| 
 | protectedinherited | 
The temperature to set after a power-on. Set to <= -999 to not use [default].
Definition at line 301 of file stdCamera.hpp.
| 
 | privateinherited | 
The application's state. Never ever set this directly, use state(const stateCodeT & s).
Definition at line 558 of file MagAOXApp.hpp.
| 
 | privateinherited | 
Definition at line 561 of file MagAOXApp.hpp.
| 
 | 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.
| 
 | protectedinherited | 
The maximum exposure time stepsize, used for INDI attributes.
Definition at line 368 of file stdCamera.hpp.
| 
 | protectedinherited | 
The FPS step size, used for INDI attributes.
Definition at line 375 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 448 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 452 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 444 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 440 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 432 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 436 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 314 of file stdCamera.hpp.
| 
 | privateinherited | 
The save-set user id of the process.
Definition at line 406 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Status of synchronization, true is on, false is off.
Definition at line 391 of file stdCamera.hpp.
| 
 | protectedinherited | 
Target status of m_synchro.
Definition at line 389 of file stdCamera.hpp.
| 
 | protectedinherited | 
The path to the system directory, for PID file, etc.
Definition at line 180 of file MagAOXApp.hpp.
| 
 | inherited | 
Definition at line 81 of file telemeter.hpp.
| 
 | protectedinherited | 
Whether or not the temperature control system is on its target temperature.
Definition at line 323 of file stdCamera.hpp.
| 
 | protectedinherited | 
Whether or not temperature control is active.
Definition at line 320 of file stdCamera.hpp.
| 
 | protectedinherited | 
Desired state of temperature control.
Definition at line 321 of file stdCamera.hpp.
| 
 | protectedinherited | 
Camera specific description of temperature control status.
Definition at line 325 of file stdCamera.hpp.
| 
 | protected | 
Tolerance in degrees C to declare the temperature control locked.
Definition at line 150 of file pvcamCtrl.hpp.
Referenced by getTemp().
| 
 | protectedinherited | 
The channel sending this shutter's trigger.
Definition at line 49 of file dssShutter.hpp.
| 
 | protectedinherited | 
The current trigger state. -1 is unknown, 0 is low, 1 is high.
Definition at line 60 of file dssShutter.hpp.
| 
 | protectedinherited | 
The size of the type, in bytes. Result of sizeof.
Definition at line 134 of file frameGrabber.hpp.
| 
 | staticconstexprprotectedinherited | 
Flag controlling whether INDI is used. If false, then no INDI code executes.
Definition at line 636 of file MagAOXApp.hpp.
| 
 | protectedinherited | 
Definition at line 159 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 164 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 169 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 350 of file stdCamera.hpp.
| 
 | protectedinherited | 
The current vshift speed name.
Definition at line 346 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 344 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 343 of file stdCamera.hpp.
| 
 | protectedinherited | 
The user requested vshift speed name, to be set by derived()
Definition at line 347 of file stdCamera.hpp.
| 
 | protectedinherited | 
Definition at line 152 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The width of the image, once deinterlaced etc.
Definition at line 130 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 148 of file frameGrabber.hpp.
| 
 | protectedinherited | 
Definition at line 151 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The x-binning according to the framegrabber.
Definition at line 136 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The y-binning according to the framegrabber.
Definition at line 137 of file frameGrabber.hpp.
| 
 | protectedinherited | 
The name of the PID file.
Definition at line 486 of file MagAOXApp.hpp.