1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
//=============================================================================
// MuseScore
// Music Composition & Notation
//
// Copyright (C) 2018 Werner Schweer
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License version 2
// as published by the Free Software Foundation and appearing in
// the file LICENCE.GPL
//=============================================================================
#ifndef __SCOREDIFFMODEL_H__
#define __SCOREDIFFMODEL_H__
namespace Ms {
struct BaseDiff;
class ScoreDiff;
struct TextDiff;
//---------------------------------------------------------
// RawScoreDiffModel
//---------------------------------------------------------
class RawScoreDiffModel : public QAbstractListModel {
Q_OBJECT
ScoreDiff* _diff;
std::vector<const TextDiff*> _textDiffs;
bool _skipEqual;
public:
RawScoreDiffModel(ScoreDiff* d, bool skipEqual = true, QObject* parent = nullptr);
int rowCount(const QModelIndex& parent = QModelIndex()) const override;
QVariant data(const QModelIndex& index, int role) const override;
public slots:
void update();
};
//---------------------------------------------------------
// ScoreDiffModel
//---------------------------------------------------------
class ScoreDiffModel : public QAbstractListModel {
Q_OBJECT
ScoreDiff* _diff;
public:
ScoreDiffModel(ScoreDiff* d, QObject* parent = nullptr) : QAbstractListModel(parent), _diff(d) {}
int rowCount(const QModelIndex& parent = QModelIndex()) const override;
QVariant data(const QModelIndex& index, int role) const override;
const BaseDiff* diffItem(const QModelIndex& index) const;
public slots:
void diffAboutToBeUpdated() { beginResetModel(); }
void diffUpdated() { endResetModel(); }
};
} // namespace Ms
#endif
|