Merge branch 'master' of https://github.com/szmoore/MCTX3420
[matches/MCTX3420.git] / server / sensor.h
index bd43fc1..2e7bf4a 100644 (file)
@@ -8,17 +8,24 @@
 
 #include "data.h"
 
+
+
 /** Number of sensors **/
-#define NUMSENSORS 
+#define NUMSENSORS 10
 
+/** Sensor ids - there should be correspondence with the names in g_sensor_names **/
 typedef enum SensorId 
 {
-       ANALOG_TEST0,
-       ANALOG_TEST1,
-       ANALOG_FAIL0,
-       DIGITAL_TEST0,
-       DIGITAL_TEST1,
-       DIGITAL_FAIL0
+       STRAIN0,
+       STRAIN1,
+       STRAIN2,
+       STRAIN3,
+       PRESSURE0,
+       PRESSURE1,
+       PRESSURE_FEEDBACK,
+       MICROPHONE,
+       ENCLOSURE.
+       DILATOMETER
 } SensorId;
 
 
@@ -26,7 +33,6 @@ typedef enum SensorId
 /** Human readable names for the sensors **/
 extern const char * g_sensor_names[NUMSENSORS];
 
-
 /** Structure to represent a sensor **/
 typedef struct
 {
@@ -34,13 +40,14 @@ typedef struct
        SensorId id;
        /** DataFile to store sensor values in **/
        DataFile data_file;
-       /** Indicates whether the Sensor should record data **/
-       bool record_data;
+       /** Indicates whether the Sensor is active or not **/
+       bool activated;
        /** Thread the Sensor is running in **/
        pthread_t thread;
        /** Most recently recorded data **/
        DataPoint newest_data;
-
+       
+       
 } Sensor;
 
 // Structure to define the warning and error thresholds of the sensors
@@ -50,19 +57,16 @@ typedef struct
        double min_error;
        double max_warn;
        double min_warn;
-} SensorThres;
+} SensorThreshold;
 
 extern void Sensor_Init(); // One off initialisation of *all* sensors
 
-extern void Sensor_StartAll(const char * experiment_name); // Start all Sensors recording data
-extern void Sensor_StopAll(); // Stop all Sensors recording data
-extern void Sensor_Start(Sensor * s, const char * experiment_name); // Start a sensor recording datas
-extern void Sensor_Stop(Sensor * s); // Stop a Sensor from recording data
-
+extern void Sensor_SetModeAll(ControlModes mode, void * arg);
+extern void Sensor_SetMode(Sensor * s, ControlModes mode, void * arg);
 
 extern void * Sensor_Loop(void * args); // Main loop for a thread that handles a Sensor
 extern bool Sensor_Read(Sensor * s, DataPoint * d); // Read a single DataPoint, indicating if it has changed since the last one
-extern void Sensor_CheckData(SensorId id, DataPoint * d); // Check a DataPoint
+extern void Sensor_CheckData(SensorId id, double value); // Check a DataPoint
 extern Sensor * Sensor_Identify(const char * str); // Identify a Sensor from a string Id
 
 extern void Sensor_Handler(FCGIContext *context, char * params); // Handle a FCGI request for Sensor data

UCC git Repository :: git.ucc.asn.au