File: logviewer.cpp

package info (click to toggle)
ktorrent 25.04.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 25,104 kB
  • sloc: cpp: 40,482; xml: 1,163; python: 182; sh: 10; makefile: 5
file content (129 lines) | stat: -rw-r--r-- 3,537 bytes parent folder | download
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
123
124
125
126
127
128
129
/*
    SPDX-FileCopyrightText: 2005 Joris Guisson <joris.guisson@gmail.com>
    SPDX-License-Identifier: GPL-2.0-or-later
*/

#include "logviewer.h"

#include <QApplication>
#include <QBoxLayout>
#include <QIcon>
#include <QMenu>

#include <KConfig>
#include <KLocalizedString>

#include "logflags.h"
#include "logviewerpluginsettings.h"

namespace kt
{
LogViewer::LogViewer(LogFlags *flags, QWidget *parent)
    : Activity(i18n("Log"), QStringLiteral("utilities-log-viewer"), 100, parent)
    , use_rich_text(true)
    , flags(flags)
    , suspended(false)
    , menu(nullptr)
    , max_block_count(200)
{
    setToolTip(i18n("View the logging output generated by KTorrent"));
    QVBoxLayout *layout = new QVBoxLayout(this);
    output = new QTextBrowser(this);
    layout->setContentsMargins(0, 0, 0, 0);
    layout->setSpacing(0);
    layout->addWidget(output);
    output->document()->setMaximumBlockCount(max_block_count);
    output->setContextMenuPolicy(Qt::CustomContextMenu);
    connect(output, &QTextBrowser::customContextMenuRequested, this, &LogViewer::showMenu);

    suspend_action = new QAction(QIcon::fromTheme(QStringLiteral("media-playback-pause")), i18n("Suspend Output"), this);
    suspend_action->setCheckable(true);
    connect(suspend_action, &QAction::toggled, this, &LogViewer::suspend);
}

LogViewer::~LogViewer()
{
}

void LogViewer::message(const QString &line, unsigned int arg)
{
    if (suspended)
        return;

    /*
        IMPORTANT: because QTextBrowser is not thread safe, we must use the Qt event mechanism
        to add strings to it, this will ensure that strings will only be added in the main application
        thread.
    */
    if (arg == 0x00 || flags->checkFlags(arg)) {
        if (!mutex.tryLock()) // Drop the message if we cannot acquire the lock, no deadlocks
            return;

        if (use_rich_text) {
            pending.append(flags->getFormattedMessage(arg, line));
        } else {
            pending.append(line);
        }

        while (pending.size() > max_block_count)
            pending.pop_front();
        mutex.unlock();
    }
}

void LogViewer::processPending()
{
    // Copy to tmp list so that we do not get a deadlock when Qt tries to print something when we add lines to the output
    QStringList tmp;
    {
        if (!mutex.tryLock()) // No deadlocks
            return;

        tmp = pending;
        pending.clear();
        mutex.unlock();
    }

    for (const QString &line : std::as_const(tmp)) {
        QTextCharFormat fm = output->currentCharFormat();
        output->append(line);
        output->setCurrentCharFormat(fm);
    }
}

void LogViewer::setRichText(bool val)
{
    use_rich_text = val;
}

void LogViewer::setMaxBlockCount(int max)
{
    max_block_count = max;
    output->document()->setMaximumBlockCount(max);
}

void LogViewer::showMenu(const QPoint &pos)
{
    if (!menu) {
        menu = output->createStandardContextMenu();
        QAction *first = menu->actions().at(0);
        QAction *sep = menu->insertSeparator(first);
        menu->insertAction(sep, suspend_action);
    }
    menu->popup(output->viewport()->mapToGlobal(pos));
}

void LogViewer::suspend(bool on)
{
    suspended = on;
    QTextCharFormat fm = output->currentCharFormat();
    if (on)
        output->append(i18n("<font color=\"#FF0000\">Logging output suspended</font>"));
    else
        output->append(i18n("<font color=\"#00FF00\">Logging output resumed</font>"));
    output->setCurrentCharFormat(fm);
}

}

#include "moc_logviewer.cpp"