X-Git-Url: http://pilppa.org/gitweb/?a=blobdiff_plain;f=src%2FW1Device.hh;h=a9303030859cc5c0713ca48259f2cab36f4129b9;hb=557fe3a639d7bd6fd146fdc9d573cf53bb2adff0;hp=d1371e9e5214a598bd267872bfef9a076789c03f;hpb=6caee6cb22c1334701afe7aa30bcf9668ca3a5c5;p=lib1wire.git diff --git a/src/W1Device.hh b/src/W1Device.hh index d1371e9..a930303 100644 --- a/src/W1Device.hh +++ b/src/W1Device.hh @@ -14,8 +14,10 @@ #include #include -#include "Data.hh" -#include "DeviceTypeSensor.hh" +#include +#include +#include +#include #ifndef W1_SCAN_ROOTDIR #define W1_SCAN_ROOTDIR "/sys/bus/w1/devices" @@ -26,32 +28,27 @@ #endif namespace w1 { - class W1Device : public plp::DeviceTypeSensor { + class W1Device : public plp::SensorDevice { public: - W1Device(int family_code_param, - std::string device_id_param, + W1Device(std::string device_id_param, + std::string device_type_param, dirent *direntry_param); virtual ~W1Device(); - int get_w1_family_code(); - std::string get_id(); std::string get_name(); void set_name(std::string name_param); void printout(); plp::Data *get_data(); - void save_data(); + plp::DataReader *get_device_data(); protected: - virtual std::vector *get_raw_data() = 0; - virtual unsigned int get_data_decimal_precision() = 0; - void collect_data(plp::Data *data); - std::string to_string(double val, int digit_count); - //Data *get_formatted_data(Data *data); - virtual bool is_supported_w1_family_code(int family_code) = 0; - int family_code; - std::string id; - std::string name; std::string dir_path; std::string slave_file; std::list memory_cache; + plp::DataReader *reader; + void save_and_clean_cache(); + virtual std::vector *get_raw_data() = 0; + virtual unsigned int get_data_decimal_precision() = 0; + void cache(plp::Data *data); + std::string to_string(double val, int digit_count); }; }