]> pilppa.org Git - lib1wire.git/blobdiff - src_test/test_w1_datalog_read.cc
sensor data read fixes.
[lib1wire.git] / src_test / test_w1_datalog_read.cc
index 1ba7005ab3584c96b81b68c7b533de09954fb71c..48425e21b342069775512f050fcaeb0bc9c2d85d 100644 (file)
 #include <stdlib.h>
 
 #include <plp/log.h>
+#include <plp/Date.hh>
+#include <plp/DataReader.hh>
+#include <plp/DeviceConfig.hh>
+#include <plp/Device.hh>
+#include <plp/SensorDevice.hh>
 
-#include "Date.hh"
-#include "DeviceData.hh"
-#include "DeviceConfig.hh"
 #include "Factory.hh"
-#include "W1Util.hh"
 
 using namespace std;
 using namespace plp;
@@ -47,53 +48,62 @@ bool try_parse_long(const char *str, long *result) {
 }
 
 int main(int argc, char** argv) {
-       string                  loc;
-       Data                    *fdata;
-       Data                    *ldata;
-       DeviceData              *dta;
-       DataRange               *dr;
-       DataRange               *dr2;
-       list<DeviceData *>      dta_list;
+       string                          loc;
+       Data                            *fdata;
+       Data                            *ldata;
+       DataReader                      *reader;
+       Device                          *dev;
+       SensorDevice                    *device;
+       DataRange                       *dr;
+       DataRange                       *dr2;
+       list<Device *>                  dev_lst;
+       list<Device *>::iterator        list_iter;
 
        // default values than can be overwritten with parameters
-       loc     = "/tmp/w1data";
+       loc     = DeviceConfig::get_base_dir_name();
        if (argc > 1) {
                loc     = argv[1];
                log_info("storage location: %s\n", loc.c_str());
+               DeviceConfig::set_base_dir_name(loc);
        }
        else {
                log_warning("No storage location parameter given, using default location: %s\n", loc.c_str());
        }
-       DeviceConfig::set_base_dir_name(loc);
-       dta_list        = Factory::get_device_data_list();
-       for(list<DeviceData *>::iterator list_iter = dta_list.begin(); list_iter != dta_list.end(); list_iter++) {
-               dta     = (DeviceData *)*list_iter;
-               if (dta != NULL) {
-                       dr      = dta->get_data_range();
-                       if (dr != NULL) {
-                               fdata   = dr->get_first_data();
-                               if (fdata != NULL) {
-                                       fdata->printout();
-                                       ldata   = dr->get_last_data();
-                                       if (ldata != NULL) {
-                                               ldata->printout();
-                                               plp::Date d1;
-                                               plp::Date d2;
+       dev_lst = Factory::get_device_list();
+       for(list_iter = dev_lst.begin(); list_iter != dev_lst.end(); list_iter++) {
+               dev     = (Device *)*list_iter;
+               if (dev != NULL) {
+                       device  = dynamic_cast<SensorDevice *>(dev);
+                       if (device != NULL) {
+                               reader  = device->get_device_data();
+                               if (reader != NULL) {
+                                       dr      = reader->get_data_range();
+                                       if (dr != NULL) {
+                                               fdata   = dr->get_first();
+                                               if (fdata != NULL) {
+                                                       fdata->printout();
+                                                       ldata   = dr->get_last();
+                                                       if (ldata != NULL) {
+                                                               ldata->printout();
+                                                               plp::Date d1;
+                                                               plp::Date d2;
 
-                                               d1      = fdata->get_date();
-                                               d2      = ldata->get_date();
-                                               dr2     = dta->get_data(&d1, &d2);
-                                               if (dr2 != NULL) {
-                                                       dr2->printout();
-                                                       delete(dr2);
+                                                               d1      = fdata->get_date();
+                                                               d2      = ldata->get_date();
+                                                               dr2     = reader->get_data(&d1, &d2);
+                                                               if (dr2 != NULL) {
+                                                                       dr2->printout();
+                                                                       delete(dr2);
+                                                               }
+                                                               delete(ldata);
+                                                       }
+                                                       delete(fdata);
                                                }
-                                               delete(ldata);
+                                               delete(dr);
                                        }
-                                       delete(fdata);
+                                       delete(reader);
                                }
-                               delete(dr);
                        }
-                       delete(dta);
                }
        }
        return 0;