summaryrefslogtreecommitdiff
path: root/gui/storageview.h
blob: 0518d8fba8d640ab1435c77908a73a30efddbbb9 (plain)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// Simulator for the RISC-V[ECTOR] mini-ISA
// Copyright (C) 2025 Siddarth Suresh
// Copyright (C) 2025 bdunahu

// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.

// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.

// You should have received a copy of the GNU General Public License
// along with this program.  If not, see <https://www.gnu.org/licenses/>.

#ifndef STORAGEVIEW_H
#define STORAGEVIEW_H

#include <QAbstractTableModel>
#include <QVector>

// see https://doc.qt.io/qt-6/qabstracttablemodel.html
class StorageView : public QAbstractTableModel
{
	Q_OBJECT
  public:
	/**
	 * Constructor. Initializes a clean StorageView object with
	 * `rows' rows.
	 * @param the number of rows
	 */
	StorageView(int rows, QObject *parent = nullptr);

	/**
	 * Returns the number of rows in this table.
	 * @param the parent
	 * @return the number of rows under the given parent.
	 */
	int rowCount(const QModelIndex &) const override;
	/**
	 * Returns the number of columns in this table.
	 * @param the parent
	 * @return the number of columns under the given parent (hint: it's
	 * LINE_SIZE)
	 */
	int columnCount(const QModelIndex &) const override;

	/**
	 * Returns a properly formatted cell, including alignment.This function is
	 * specific to the implementation details of QAbstractTableModel.
	 */
	QVariant
	data(const QModelIndex &index, int role = Qt::DisplayRole) const override;

	/**
	 * Adds custom formatting options for row and column headers.
	 */
	QVariant headerData(
		int section,
		Qt::Orientation o,
		int role = Qt::DisplayRole) const override;

	/**
	 * Ensures the table is enabled, but not selectable.
	 */
	Qt::ItemFlags flags(const QModelIndex &i) const override;

	/**
	 * @param field to assign to `this->d'
	 */
	void set_data(const QVector<QVector<int>> &data);

  public slots:
	void set_hex_display(bool hex);

  private:
	/**
	 * The number of rows in this table.
	 */
	int r;
	/**
	 * Whether or not the headers should be displayed in hex.
	 */
	bool is_hex = true;
	/**
	 * The data this table displays.
	 */
	QVector<QVector<int>> d;
};

#endif // STORAGEVIEW_H