Adapt LineModel to being autotested

This commit is contained in:
Tobias Fella
2025-12-26 22:17:28 +01:00
committed by Tobias Fella
parent 53dc9c1944
commit 45cee495a5
7 changed files with 17 additions and 25 deletions

View File

@@ -212,10 +212,8 @@ void ModelTest::testLineModel()
auto model = new LineModel();
auto tester = new QAbstractItemModelTester(model);
tester->setUseFetchMore(true);
auto quickDocument = new QQuickTextDocument(new QQuickItem());
auto document = new QTextDocument();
quickDocument->setTextDocument(document);
model->setDocument(quickDocument);
model->setDocument(document);
document->setPlainText(u"foo\nbar\n\nbaz"_s);
}

View File

@@ -116,7 +116,7 @@ Components.AbstractMaximizeComponent {
id: repeater
model: LineModel {
id: lineModel
document: codeText.textDocument
Component.onCompleted: setDocument(codeText.textDocument)
}
delegate: QQC2.Label {
id: label

View File

@@ -85,7 +85,7 @@ Kirigami.Page {
id: repeater
model: LineModel {
id: lineModel
document: sourceTextArea.textDocument
Component.onCompleted: setDocument(sourceTextArea.textDocument)
}
delegate: QQC2.Label {
id: label

View File

@@ -103,7 +103,7 @@ Kirigami.Page {
id: repeater
model: LineModel {
id: lineModel
document: sourceTextArea.textDocument
Component.onCompleted: setDocument(sourceTextArea.textDocument)
}
delegate: QQC2.Label {
id: label

View File

@@ -104,7 +104,7 @@ QQC2.Control {
id: repeater
model: LineModel {
id: lineModel
document: codeText.textDocument
Component.onCompleted: setDocument(codeText.textDocument)
}
delegate: QQC2.Label {
id: label

View File

@@ -8,12 +8,7 @@ LineModel::LineModel(QObject *parent)
{
}
QQuickTextDocument *LineModel::document() const
{
return m_document;
}
void LineModel::setDocument(QQuickTextDocument *document)
void LineModel::setDocument(QTextDocument *document)
{
if (document == m_document) {
return;
@@ -25,6 +20,11 @@ void LineModel::setDocument(QQuickTextDocument *document)
resetModel();
}
void LineModel::setDocument(QQuickTextDocument *document)
{
setDocument(document->textDocument());
}
QVariant LineModel::data(const QModelIndex &index, int role) const
{
if (!index.isValid()) {
@@ -37,8 +37,7 @@ QVariant LineModel::data(const QModelIndex &index, int role) const
}
if (role == LineHeightRole) {
auto textDoc = m_document->textDocument();
return int(textDoc->documentLayout()->blockBoundingRect(textDoc->findBlockByNumber(row)).height());
return int(m_document->documentLayout()->blockBoundingRect(m_document->findBlockByNumber(row)).height());
}
return {};
}
@@ -49,7 +48,7 @@ int LineModel::rowCount(const QModelIndex &parent) const
if (m_document == nullptr) {
return 0;
}
return m_document->textDocument()->blockCount();
return m_document->blockCount();
}
QHash<int, QByteArray> LineModel::roleNames() const

View File

@@ -8,7 +8,7 @@
#include <QQmlEngine>
#include <QQuickTextDocument>
#include <QTextBlock>
#include <qtmetamacros.h>
#include <QTextDocument>
/**
* @class LineModel
@@ -22,11 +22,6 @@ class LineModel : public QAbstractListModel
Q_OBJECT
QML_ELEMENT
/**
* @brief The QQuickTextDocument that is being handled.
*/
Q_PROPERTY(QQuickTextDocument *document READ document WRITE setDocument NOTIFY documentChanged)
public:
/**
* @brief Defines the model roles.
@@ -38,8 +33,8 @@ public:
explicit LineModel(QObject *parent = nullptr);
[[nodiscard]] QQuickTextDocument *document() const;
void setDocument(QQuickTextDocument *document);
void setDocument(QTextDocument *document);
Q_INVOKABLE void setDocument(QQuickTextDocument *document);
/**
* @brief Get the given role value at the given index.
@@ -76,5 +71,5 @@ Q_SIGNALS:
void documentChanged();
private:
QPointer<QQuickTextDocument> m_document = nullptr;
QPointer<QTextDocument> m_document = nullptr;
};