X-Git-Url: http://pilppa.org/gitweb/?a=blobdiff_plain;f=src%2FW1Device.hh;h=a9303030859cc5c0713ca48259f2cab36f4129b9;hb=557fe3a639d7bd6fd146fdc9d573cf53bb2adff0;hp=321159abecd682afd1a0501ff99921dd98df98a0;hpb=d58713adbc518552c11fd19bd21ae8bd11ab434f;p=lib1wire.git diff --git a/src/W1Device.hh b/src/W1Device.hh index 321159a..a930303 100644 --- a/src/W1Device.hh +++ b/src/W1Device.hh @@ -14,7 +14,10 @@ #include #include -#include "Data.hh" +#include +#include +#include +#include #ifndef W1_SCAN_ROOTDIR #define W1_SCAN_ROOTDIR "/sys/bus/w1/devices" @@ -25,35 +28,27 @@ #endif namespace w1 { - class W1Device { + 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); - virtual std::string get_unit() = 0; - virtual std::string get_device_type() = 0; - Data *get_and_collect_data(); - virtual void save_data(); - virtual void printout(); + void printout(); + plp::Data *get_data(); + plp::DataReader *get_device_data(); protected: + 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 collect_data(Data *data); + void cache(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; - private: }; }