mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 14:25:27 +00:00
ddfc384b61
Change the remove() function of the cylinder and weight models to take the index by value. The code used to take it by reference and the reference would be invalidated when removing rows from the model! Reported-by: Gaetan Bisson <bisson@archlinux.org> Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
41 lines
1 KiB
C++
41 lines
1 KiB
C++
// SPDX-License-Identifier: GPL-2.0
|
|
#ifndef WEIGHTMODEL_H
|
|
#define WEIGHTMODEL_H
|
|
|
|
#include "cleanertablemodel.h"
|
|
#include "core/dive.h"
|
|
|
|
/* Encapsulation of the Weight Model, that represents
|
|
* the current weights on a dive. */
|
|
class WeightModel : public CleanerTableModel {
|
|
Q_OBJECT
|
|
public:
|
|
enum Column {
|
|
REMOVE,
|
|
TYPE,
|
|
WEIGHT
|
|
};
|
|
|
|
explicit WeightModel(QObject *parent = 0);
|
|
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override;
|
|
int rowCount(const QModelIndex &parent = QModelIndex()) const override;
|
|
Qt::ItemFlags flags(const QModelIndex &index) const override;
|
|
bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole) override;
|
|
|
|
void passInData(const QModelIndex &index, const QVariant &value);
|
|
void add();
|
|
void clear();
|
|
void updateDive();
|
|
weightsystem_t *weightSystemAt(const QModelIndex &index);
|
|
bool changed;
|
|
|
|
public
|
|
slots:
|
|
void remove(QModelIndex index);
|
|
void weightsystemsReset(const QVector<dive *> &dives);
|
|
|
|
private:
|
|
int rows;
|
|
};
|
|
|
|
#endif
|