/* SleepLib Machine Class Header * * Copyright (c) 2011-2014 Mark Watkins * * This file is subject to the terms and conditions of the GNU General Public * License. See the file COPYING in the main directory of the Linux * distribution for more details. */ #ifndef MACHINE_H #define MACHINE_H #include #include #include #include #include #include #include #include #include #include #include "SleepLib/preferences.h" #include "SleepLib/machine_common.h" #include "SleepLib/event.h" #include "SleepLib/session.h" #include "SleepLib/schema.h" #include "SleepLib/day.h" class Day; class Session; class Profile; class Machine; /*! \class SaveThread \brief This class is used in the multithreaded save code.. It accelerates the indexing of summary data. */ class SaveThread: public QThread { Q_OBJECT public: SaveThread(Machine *m, QString p) { machine = m; path = p; } //! \brief Static millisecond sleep function.. Can be used from anywhere static void msleep(unsigned long msecs) { QThread::msleep(msecs); } //! \brief Start Save processing thread running virtual void run(); protected: Machine *machine; QString path; signals: //! \brief Signal sent to update the Progress Bar void UpdateProgress(int i); }; class ImportTask:public QRunnable { public: explicit ImportTask() {} virtual ~ImportTask() {} virtual void run() {} }; class MachineLoader; /*! \class Machine \brief This Machine class is the Heart of SleepyLib, representing a single Machine and holding it's data */ class Machine { friend class SaveThread; friend class MachineLaoder; public: /*! \fn Machine(MachineID id=0); \brief Constructs a Machine object with MachineID id If supplied MachineID is zero, it will generate a new unused random one. */ Machine(MachineID id = 0); virtual ~Machine(); //! \brief Load all Machine summary data bool Load(); bool LoadSummary(bool everything = false); //! \brief Save all Sessions where changed bit is set. bool Save(); bool SaveSummary(); //! \brief Save individual session bool SaveSession(Session *sess); //! \brief Deletes the crud out of all machine data in the SleepLib database bool Purge(int secret); //! \brief Unlink a session from any Machine related indexes bool unlinkSession(Session * sess); bool unlinkDay(Day * day); inline bool hasChannel(ChannelID code) { return m_availableChannels.contains(code); } //! \brief Contains a secondary index of day data, containing just this machines sessions QMap day; //! \brief Contains all sessions for this machine, indexed by SessionID QHash sessionlist; //! \brief List of text machine properties, like brand, model, etc... QHash properties; //! \brief Returns a pointer to a valid Session object if SessionID exists Session *SessionExists(SessionID session); //! \brief Adds the session to this machine object, and the Master Profile list. (used during load) bool AddSession(Session *s); //! \brief Find the date this session belongs in, according to profile settings QDate pickDate(qint64 start); const QString getDataPath(); const QString getEventsPath(); const QString getSummariesPath(); const QString getBackupPath(); //! \brief Returns the machineID as a lower case hexadecimal string QString hexid() { return QString().sprintf("%08lx", m_id); } //! \brief Unused, increments the most recent sessionID SessionID CreateSessionID() { return highest_sessionid + 1; } //! \brief Returns this objects MachineID const MachineID &id() { return m_id; } void setId(MachineID id) { m_id = id; } //! \brief Returns the date of the first loaded Session const QDate &FirstDay() { return firstday; } //! \brief Returns the date of the most recent loaded Session const QDate &LastDay() { return lastday; } //! \brief Add a new task to the multithreaded save code void queSaveList(Session * sess); bool hasModifiedSessions(); //! \brief Grab the next task in the multithreaded save code Session *popSaveList(); //! \brief Start the save threads which handle indexing, file storage and waveform processing void StartSaveThreads(); //! \brief Finish the save threads and safely close them void FinishSaveThreads(); //! \brief The list of sessions that need saving (for multithreaded save code) QList m_savelist; //yuck QVectorthread; volatile int savelistCnt; int savelistSize; QMutex listMutex; QSemaphore *savelistSem; void lockSaveMutex() { listMutex.lock(); } void unlockSaveMutex() { listMutex.unlock(); } void skipSaveTask() { lockSaveMutex(); m_donetasks++; unlockSaveMutex(); } void clearSkipped() { skipped_sessions = 0; } int skippedSessions() { return skipped_sessions; } inline int totalTasks() { return m_totaltasks; } inline void setTotalTasks(int value) { m_totaltasks = value; } inline int doneTasks() { return m_donetasks; } inline MachineType type() const { return info.type; } inline QString brand() const { return info.brand; } inline QString loaderName() const { return info.loadername; } inline QString model() const { return info.model; } inline QString modelnumber() const { return info.modelnumber; } inline QString serial() const { return info.serial; } inline QString series() const { return info.series; } inline quint32 cap() const { return info.cap; } inline int version() const { return info.version; } inline QDateTime lastImported() const { return info.lastimported; } inline void setModel(QString value) { info.model = value; } inline void setBrand(QString value) { info.brand = value; } inline void setSerial(QString value) { info.serial = value; } inline void setType(MachineType type) { info.type = type; } inline void setCap(quint32 value) { info.cap = value; } bool saveSessionInfo(); bool loadSessionInfo(); void setLoaderName(QString value); QList availableChannels(quint32 chantype); MachineLoader * loader() { return m_loader; } // much more simpler multithreading... void queTask(ImportTask * task); void runTasks(); QMutex saveMutex; void setInfo(MachineInfo inf); const MachineInfo getInfo() { return info; } void updateChannels(Session * sess); protected: MachineInfo info; QDate firstday, lastday; SessionID highest_sessionid; MachineID m_id; MachineType m_type; QString m_path; MachineLoader * m_loader; bool changed; bool firstsession; int m_totaltasks; int m_donetasks; int skipped_sessions; volatile bool m_save_threads_running; QList m_tasklist; QHash m_availableChannels; }; /*! \class CPAP \brief A CPAP classed machine object.. */ class CPAP: public Machine { public: CPAP(MachineID id = 0); virtual ~CPAP(); }; /*! \class Oximeter \brief An Oximeter classed machine object.. */ class Oximeter: public Machine { public: Oximeter(MachineID id = 0); virtual ~Oximeter(); protected: }; /*! \class SleepStage \brief A SleepStage classed machine object.. */ class SleepStage: public Machine { public: SleepStage(MachineID id = 0); virtual ~SleepStage(); protected: }; /*! \class PositionSensor \brief A PositionSensor classed machine object.. */ class PositionSensor: public Machine { public: PositionSensor(MachineID id = 0); virtual ~PositionSensor(); protected: }; #endif // MACHINE_H