]> git.sesse.net Git - pkanalytics/commitdiff
Clean out the refresh-on-demand code from EventsModel.
authorSteinar H. Gunderson <sgunderson@bigfoot.com>
Mon, 1 May 2023 15:00:07 +0000 (17:00 +0200)
committerSteinar H. Gunderson <sgunderson@bigfoot.com>
Mon, 1 May 2023 15:00:07 +0000 (17:00 +0200)
events.cpp
events.h

index 5752d82ca4fb5c8d7cfed40ec705e1d17f698258..4ce3e86c67604f3692ea68bc8a29c7e992feb754 100644 (file)
@@ -10,6 +10,11 @@ using namespace std;
 
 string format_timestamp(uint64_t pos);
 
+EventsModel::EventsModel(sqlite3 *db) : db(db)
+{
+       load_data();
+}
+
 QVariant EventsModel::headerData(int section, Qt::Orientation orientation, int role) const
 {
        if (role != Qt::DisplayRole) {
@@ -33,13 +38,13 @@ QVariant EventsModel::data(const QModelIndex &index, int role) const
        if (role != Qt::DisplayRole) {
                return QVariant();
        }
-       refresh_if_needed();
        if (index.column() == 0) {
                return QString::fromUtf8(format_timestamp(events[index.row()].t));
        } else if (index.column() == 1) {
                optional<int> player_id = events[index.row()].player_id;
                if (player_id) {
-                       const Player &p = players[*player_id];
+                       auto p_it = players.find(*player_id);
+                       const Player &p = p_it->second;
                        return QString::fromUtf8(p.name + " (" + p.number + ")");
                } else {
                        return QVariant();
@@ -50,15 +55,10 @@ QVariant EventsModel::data(const QModelIndex &index, int role) const
        return QVariant();
 }
 
-void EventsModel::refresh_if_needed() const
+void EventsModel::load_data()
 {
-       if (!stale) {
-               return;
-       }
-
        players.clear();
        events.clear();
-       stale = false;
 
        // Read the players.
        sqlite3_stmt *stmt;
@@ -115,9 +115,6 @@ void EventsModel::refresh_if_needed() const
                fprintf(stderr, "SELECT finalize: %s\n", sqlite3_errmsg(db));
                abort();
        }
-
-       // TODO what if data changes externally?
-       //emit dataChanged(QModelIndex(
 }
 
 unsigned EventsModel::insert_event(uint64_t t, int player_id)
index 56fcbaff53a07ec93278b9af3a9d4bcc94794229..910e2b92a6517ad88803e16b9b42a405fa010e9a 100644 (file)
--- a/events.h
+++ b/events.h
 class EventsModel : public QAbstractTableModel
 {
 public:
-       EventsModel(sqlite3 *db) : db(db) {}
+       EventsModel(sqlite3 *db);
 
        int rowCount(const QModelIndex &parent) const override
        {
-               refresh_if_needed();
                return events.size();
        }
        int columnCount(const QModelIndex &column) const override
@@ -44,7 +43,7 @@ private:
                std::string number;
                std::string name;
        };
-       mutable std::map<int, Player> players;
+       std::map<int, Player> players;
 
        struct Event {
                int event_id;
@@ -52,12 +51,11 @@ private:
                std::optional<int> player_id;
                std::string type;
        };
-       mutable std::vector<Event> events;
-       mutable bool stale = true;
+       std::vector<Event> events;
 
        sqlite3 *db;
 
-       void refresh_if_needed() const;
+       void load_data();
 };
 
 #endif  // !defined(_EVENTS_H)