aboutsummaryrefslogtreecommitdiffstats
path: root/src/qmlls/qtextcursor.cpp
blob: 79289c3fa5da8d67f0d291754910285f265dcb9f (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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
// Copyright (C) 2021 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only

#include "qtextcursor_p.h"
#include "qtextdocument_p.h"
#include "qtextblock_p.h"

namespace Utils {

class TextFrame;
class TextTable;
class TextTableCell;

TextCursor::TextCursor(TextDocument *document) : m_document(document) { }

bool TextCursor::movePosition(TextCursor::MoveOperation op, TextCursor::MoveMode mode, int n)
{
    Q_UNUSED(n);
    switch (op) {
    case NoMove:
        return true;
    case Start:
        m_position = 0;
        break;
    case PreviousCharacter:
        while (--n >= 0) {
            if (m_position == 0)
                return false;
            --m_position;
        }
        break;
    case End:
        m_position = m_document->characterCount();
        break;
    case NextCharacter:
        while (--n >= 0) {
            if (m_position == m_document->characterCount())
                return false;
            ++m_position;
        }
        break;
    }

    if (mode == MoveAnchor)
        m_anchor = m_position;

    return false;
}

int TextCursor::position() const
{
    return m_position;
}

void TextCursor::setPosition(int pos, Utils::TextCursor::MoveMode mode)
{
    m_position = pos;
    if (mode == MoveAnchor)
        m_anchor = pos;
}

QString TextCursor::selectedText() const
{
    return m_document->toPlainText().mid(qMin(m_position, m_anchor), qAbs(m_position - m_anchor));
}

void TextCursor::clearSelection()
{
    m_anchor = m_position;
}

TextDocument *TextCursor::document() const
{
    return m_document;
}

void TextCursor::insertText(const QString &text)
{
    const QString orig = m_document->toPlainText();
    const QString left = orig.left(qMin(m_position, m_anchor));
    const QString right = orig.mid(qMax(m_position, m_anchor));
    m_document->setPlainText(left + text + right);
}

TextBlock TextCursor::block() const
{
    TextBlock current = m_document->firstBlock();
    while (current.isValid()) {
        if (current.position() <= position()
            && current.position() + current.length() > current.position())
            break;
        current = current.next();
    }
    return current;
}

int TextCursor::positionInBlock() const
{
    return m_position - block().position();
}

int TextCursor::blockNumber() const
{
    return block().blockNumber();
}

void TextCursor::removeSelectedText()
{
    insertText(QString());
}

int TextCursor::selectionEnd() const
{
    return qMax(m_position, m_anchor);
}

bool TextCursor::isNull() const
{
    return m_document == nullptr;
}

} // namespace Utils